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(57) Abstract 

The invention relates to a bus system for 
DFPs DE 16 88 A 1 and to building blocks with two 
dimensional or multidimensional programmable 
cell structures (of type FPGA, DPGA or the like), 
characterized in that a) the bus system comprises a 
plurality of electrically independent bus segments 
disconnected by nodes, b) the nodes actively 
connect or disconnect bus segments, whereby bl) 
several bus segments are joined and connected by 
gates to a bus bar located inside the node or b2) 
connection occurs directly via circuitry elements, 
drivers and/or registers, c) each node has a routing 
table where information on the structure of the 
connection is stored, d) each node has a monitoring 
unit, which verifies independently if a connection 
can be established or not 

(57) Zusammenfassung 

Ein Bussystem fur DFPs gemaB DE 44 
16 881 Al, sowie Bausteine mit zwei- oder 
mehrdimensionaler programmierbarer Zellstruktur (der Gattungen FPGA, DPGA, o.dgl.) ist dadurch gekennzeichnet, daB a) das Bussystem 
aus einer Vielzahl voneinander elektrisch unabhangiger Bussegmente besteht, die Ober Knoten getrennt sind, b) die Knoten Bussegmente 
aktiv zusammenfugen oder trennen, wobei bl) entweder zum Zusammenfugen mehrere Bussegmente Ober Tore auf eine, sich innerhalb 
des Knoten befindende Sammelschienen zusammengeschaltet werden, oder b2) die Zusammenfugung direkt Ober Schaltelemente, Treiber 
und/oder Register erfolgt, c) jeder Knoten eine Routingtabelle besitzt, in der die Informationen Ober den Aufbau der Verbindungen gespeichert 
sind, d) jeder Knoten eine Uberwachungseinheit besitzt, die selbstandig prflft, ob eine Verbindung aufgebaut werden kann oder nicht 
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Internes Bussystem ftir DFPs, sowie Bausteinen mit zwei- oder 
mehrdimensionalen programmierbaren Zellstrukturen, zur 
Bewaltigung groBer Datenmengen mit hohem Vernetzungsaufwand. 

Hintergrund der Erfindung 
Stand der Technik 

... in Systemen mit zwei- oder mehrdimensionalen 
programmierbaren Zellstrukturen ( FPGAs , DPGAs) 
In FPGAs und DPGAs befinden sich interne Bussysteme, die 
entweder global AnschluB an alle oder eine grofie Menge von 
Logikzellen haben oder eine lokale NextNeighbour-Verbindung 
aufweisen. Beiden Arten ist gemeinsam, dafi es sich urn direkte 
Verbindungen zwischen zwei oder mehreren Logikzellen handelt. 
Weiterhin kann immer genau ein Signal den Bus benutzen, es sei 
denn, dali eine Multiplexerstruktur in eine Mehrzahl von 
Logikzellen zusammen mit einer Steuerung konfiguriert wird. 

... in DFP-basierenden Systemen 

In DFP-basierenden Systemen, nach DE 44 16 881 existieren die 
selben bereits beschriebenen Bussysteme. Zusatzlich existiert 
die Moglichkeit ein Bussystem zu trennen, so dali mehrere 
getrennt nutzbare Teilbusse entstehen. 

... in IO-Bussysteme nach DE 196 54 595.1-53 
In DE 196 54 595.1-53 wird ein IO-Bussystem beschrieben, das 
eine Vielzahl Bausteininterner Bussysteme, wobei ein Baustein 
ein FPGA, DPGA, DFP oder ahnlicher sein kann, zusammenf aftt und 
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aus dem Baustein herausfiihrt. Dabei konnen Speicherbaugruppen 
Oder Peripherie Oder weitere Bausteine oben genannter Gattung 
angesteuert werden. Es existiert nur ein Adressregister, bzw. 
ein Adresszahler um die externen Adressen zu generieren. 

Probleme 

Die iiblichen Bussysteme sind nicht dazu geeigner grofte 
Datenmengen in Form von byteweise oder anders gruppierten 
Signalen zu ubertragen. Besonders wenn die Bausteine zur 
Berechnung von Algorithmen verwendet werden ist es 
erforderlich, daft eine Vielzahl von Daten (paketen) 
gleichzeitig zwischen den einzelnen konf igurierten 
Funktionsbereichen eines Bausteines ubertragen werden. In der 
iiblichen Technik mull fur jeden Datenpfad, das ist die 
Verbindung (der Bus) zweier (oder mehrerer) Funktionsblocke, 
die dieselben Daten erhalten, eine direkte Punkt zu Punkt 
Verbindung aufgebaut werden, die dann ausschlieftlich den 
Datenverkehr zwischen eben diesen Funktionsblocken regelt. Es 
kann sich immer genau ein Datenpaket auf dem Bus befinden. Der 
Vernetzungsaufwand wird extrem hoch. Die Geschwindigkeit der 
heutigen internen Busse wird begrenzt durch die maximaie 
Busbreite und die Laufzeit der Signale auf dem Bus. 
Beim in DE 196 54 595.1-53 beschriebenen IO-Bus kann pro 10- 
Zelle nur eine Art von Busverbindung aufgebaut werden, namlich 
ausschlieftlich die in dem Adressregister programmierte. Es 
besteht keine MSglichkeit auf verschiedene Datentypen oder 
Datensender zu reagieren und diese mit verschiedenen externen 
Bausteinen zu verbinden. 
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Verbesserung durch die Erfindung, Aufgabe 
Ziel der Erfindung ist es, ein Bussystem zu schaffen, das 
Daten zwischen einer Vielzahl von Funktionsblocken ubertragen 
kann, wobei sich mehrere Datenpakete gleichzeitig auf dem Bus 
befinden konnen. Dabei erkennt das Bussystem fur verschiedene 
Datentypen oder Datensender automatisch die richtige 
Verbindung und baut diese auf. 

Die Einzelheiten und besondere Ausgestaltungen, sowie Merkmale 
des erf indungsgemaften Bussystems sind Gegenstand der 
Patentanspriiche . 

Beschreibung der Erfindung 

Obersicht iiber die Erfindung, Abstrakt 

Beschrieben wird ein Bussystem, das horizontal, vertikal, 
diagonal oder in jeder beliebigen Lage auf einem Baustein 
integriert werden kann. 

Das Bussystem ist in eine Vielzahl von Segmenten unterteilt, 
wobei die Trennung der Segmente durch eine Bussteuerschaltung 
erfolgt. Diese Bussteuerschaltung wird Knoten genannnt. 
Gleichzeitig iibernimmt der Knoten das Routen, also das Steuern 
der FluBrichtung der Daten. Logikzellen oder PAE-Zellen nach 
DE 196 51 075.9-53 sind an die Knoten angeschlossen, sie 
senden und empfangen ihre Daten iiber die Knoten, wobei jedem 
Datenpaket eine Zieladresse mitgegeben werden kann. Ebenfalls 
ist das Bussystem in der Lage iiber LookUp-Tabellen, im 
Folgende Routingtabellen genannt, Zieladressen zu generieren, 
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hierzu kann vor allem das in DE 196 54 846.2-53 beschriebene 
Verfahren dienen. Die Bussysteme sind besonders zu einem 
direkten AnschluB an die in DE 196 54 595.1-53 beschriebenen 
INPUT- /OUT PUT-CELLs geeignet . Das Auf- und Abbauen von 
Verbindungen, sowie die Synchronisation der Daten erfolgt 
automatisch. Schlagt ein Aufbau fehl, da das benotigte 
Bussegment momentan belegt ist, wird der Aufbau zu einem 
spateren Zeitpunkt wiederholt. Anhand unterschiedlicher 
Datentypen oder Datensender konnen automatisch 
unterschiedliche Verbindungen aufgebaut werden. 

Detailbeschreibung der Erfindung 
Das Bussystem 

Auf einem Baustein befinden sich eine Vielzahl von Bussen, die 
horizontal, vertikal, diagonal oder in jeder beliebigen Lage 
auf dem Baustein angeordnet sind. Dabei sind die einzelnen 
Busse nicht durchgehend von einer Bausteinkante zur anderen, 
sondern sie sind in eine Mehrzahl von Bussegmenten unterteilt. 
Die Bussegmente werden durch die nachfolgend beschriebenen 
Knot en getrennt. Jedes Bussegment ist unabhangig von den 
anderen nutzbar und verschaltbar, wobei die Verschaltung von 
den Knoten ubernommen wird. Auf dem Bussystem ist kann ein 
eigenes Protokoll implementiert sein, das von den Knoten 
verwaltet wird; ebenfalls ist denkbar, dali das Protokoll von 
den Zellen, die den Bus benutzen, verwaltet wird und die 
Knoten nur passive Schalter sind. 
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Der Knoten 

Ein Knoten dient der Verschaltung der einzelnen Bussegmente 
miteinander . Ebenfalls wird das Aufschalten der Zellen auf die 
Bussegmente von den Knoten ubernommen . 

In einem Knoten sind die Bussegmente aller Richtungen 
zusammengefuhrt, das bedeutet, 

- in einem zweidimensionalen System werden die Busse aus 4 
Richtungen Norden (N) , Siiden (S) , Osten ( E) , Westen (W) auf 
den Knoten gefiihrt. 

- in einem dreidimensionalen System werden die Busse aus 6 
Richtungen Norden (N) , Siiden (S) , Osten (E) , Westen (W) , Oben 
(T), Unten (B) auf den Knoten gefiihrt. 

- in einem n-dimensionalen System werden die Busse aus n- 
Richtungen (je Dimension existiert ein Richtungsvektor dessen 
Richtung durch das Vorzeichen bestimmt wird => pro Dimension 
existieren zwei Richtungen, die durch das Vorzeichen des 
Richtungsvektors unterschieden werden) auf den Knoten gefiihrt. 

Knoten Typ A 

Innerhalb des Knotens befindet sich ein Bussystem, auf das die 
externen Busse auf geschaltet werden und das somit aus mehreren 
Sammelschienen besteht. Ein externer erster Bus wird uber ein 
Tor auf eine Sammelschiene auf geschaltet ■. Uber ein weiteres 
Tor wird die Sammelschiene auf den externen zweiten Bus 
auf geschaltet . Um Broadcasting, das Versenden von Daten an 
mehrere Empfanger, zu ermoglichen, konnen auch mehrere 
"zweite" Busse auf das interne Bussystem geschaltet werden. 
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Die Tore konnen dabei als rein passive Schalter, als 
Bustreiber oder als Register/Latch ausgestaltet sein. 

Weiterhin hat der Knoten Zugriff auf eine (oder mehrere) mit 
ihm verbundene (n) konf igurierbaren Elemente (Zellen) . Diese 
verbindet er gegebenenfalls mit einem oder mehreren der 
angrenzenden Bussegmente . 

Knoten Typ B 

Im Gegensatz zum Knoten Typ A existiert kein internes 
Bussystem. Der Knoten besteht aus n konf igurierbaren 
Schaltern, die jedes angrenzende Segment mit jedem anderen 
angrenzenden Segment verbinden konnen. Beispielsweise gilt bei 
2-dimensionalen Strukturen n=6. 



N 


Verbindung 


1 


O-W/W-0 


2 


N-S/S-N 


3 


N-O/O-N 


4 


O-S/S-0 


5 


S-W/W-S 


6 


W-N/N-W 



(N=Nord, 0=Ost, S=Sud, W=West) 

Ein Schalter kann unidirektional oder bidirektional 
ausgestaltet sein, dabei kann er ein Register oder Latch zur 
Speicherung der Daten enthalten. 
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Das "gewohnliche" Routingverfahren 

Eine Verbindung wird initiiert von einem Datensender (DS) 

dies ist ein konf igurierbares Element (Logikzelle, Buszelle 

(auch Externe gemaJi DE 196 54 595.1-53)) , der eine 

Verbindung zu einem Datenempf anger (DE) der ebenfalls aus 

einem konf igurierbaren Element besteht benbtigt. Hierzu 

teilt der DS dem Knoten seine Busanf orderung mit . Der erste 
Knoten direkt nach einem Datensender wird Initiator-Knoten 
genannt. Der entnimmt, wie nachfolgend beschrieben, einer 
internen Tabelle die Adresse des nachsten fur den 
Datenrransf ers benbtigten Knotens. 

Sofern der Knoten in der Lage ist, das erste benbtigte 

Bussegment anzusprechen das ist immer dann mbglich, wenn 

das Bussegment UND eine interne Sammelschiene des Knoten frei 

ist baut er die Verbindung auf, ansonsten weist er die 

Anforderung des DS zurUck und der DS versucht den Zugriff zu 
einem spateren Zeitpunkt noch einmal, oder wartet und halt die 
Zugrif fsanf orderung weiter aufrecht, bis der Knoten sie 
aktzeptiert. 

Jeder nachfolgende Knoten entnimmt wiederum die Adresse des 
nachsten Knotens aus seiner internen Tabelle und setzt den 
Aufbau der Verbindung fort. Ist der Knoten nicht in der Lage 
den Aufbau der Verbindung durchzuf uhren (entweder ist das 
benotigte Bussegment besetzt oder die Sammelschiene des 
Knotens ist nicht frei), so kann er entweder in einen 
Wartezustand springen, oder den Aufbau unterbrechen und einen 
Fehler an den Initiator-Knoten zuruckmelden. 
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Erst wenn eine Verbindung komplett aufgebaut ist, werden die 
Datenpakete ubertragen und der Sender erhalt erhalt die 
Quittierungssignale fur den Datenaustausch (vgl. rACK in DE 
196 51 075.9-53). Dadurch wird der Datentransf er automatisch 
mit den Datensendern synchronistiert . Schlagt der 
Verbindungsaufbau fehl und muli er zu einem spateren Zeitpunkt 
wiederholt werden, erhalt der Datensender kein 
Quittierungssignal, somit gehen keine Daten verloren. 

Ist die Verbindung komplett aufgebaut, bleibt sie so lange 
quasi-permanent (das bedeutet, sie erscheint dem DS und DE wie 
eine direkte Verbindung) stehen, bis der DS die Verbindung 
durch eine Meldung an den Initiator-Knoten wieder aufldst. 
Es ist denkbar ein Timeout-Verf ahren zu implementieren, das 
eine stehende Verbindung nach einer gewissen Zeit unterbricht, 
ins besondere dann, wenn langere Zeit kein Datentransf er 
stattgefunden hat, urn die Bussegmente fur andere Verbindungen 
freizugeben. 

Das erweiterte Routingverf ahren 

Beim bisher beschriebenen Verbindungsaufbau befinden sich die 
Adressen nur wahrend der Aufbauphase auf dem Bus. Wahrend der 
Datenubertagen werden die Adressen nicht mehr ubertragen. 
Beim Verfahren des erweiterten Verbindungsaufbaus laufen die 
Adressen standig auf separaten Leitungen mit den Daten mit. 
Dabei existieren zwei Adressierungsschemata : 
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1. Raumkoordinaten 

Als Adressen werden die Raumkoordinaten des Ziels angegeben. 
Die Raumkoordinaten sind von der gewahlten Dimension des 
Systems abhangig. Beispielsweise benutzt ein 3-dimensionales 
System die Koordinaten X/Y/Z und ein 2-dimensionales X/Y. 
Prinzipiell ist das Verfahren auf ein beliebig dimensionales 
System anwendbar. Jeder Koordinate ist ein Richtungsvektor 
zugeordnet, der angibt, ob sich die Daten/der 
Verbindungsaufbau in positiver oder negativer Richtung 
bewegen/bewegt . 

Die Daten bewegen sich vom Ursprungsknoten in eine der 
eingestellten Richtungen. Dabei wird die entsprechende 
Richtungskoordinate beim Durchlauf eines Knotens so 
modifiziert, daft 

- bei Bewegung in positiver Richtung 1 subtrahiert wird 

- bei Bewegung in negativer Richtung 1 addiert wird 

Die Zielachse ist erreicht, wenn die Koordinate 0 ist, der 
Zielknoten ist erreicht, wenn alle Koordinaten 0 sind. 

Es ist implementierungsabhangig, ob ein zweier-Komplement 
generiert wird und eine Koordinate als negative Zahl 
dargestellt wird (auf die aufaddiert wird) oder ob von einer 
positiven Zahl subtrahiert wird. Ebenfalls kann auf eine 
positive Zahl so lange aufaddiert werden, bis ein Oberlauf 
generiert wird, der die Zielposition kennzeichnet . 

Es gibt zwei sinnvolle Strategien die Laufrichtung der Daten 
festzulegen: 
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a. Statisches Verfahren: Die Daten laufen immer in dieselbe 
Richtung, d.h. es wird versucht immer die Richtung 
beizubehalten, so lange, bis ein Richtungswechsel unbedingt 
erforderlich ist. Ein Richtungswechsel ist erf orderlich, wenn 
die aktuelle Richtungskoordinate gleich null ist, d.h. deren 
Zielposition erreicht wird. 

Wird die Zielposition einer Koordinate erreicht, werden die 
Daten in Richtung der Koordinaten bewegt, die ungleich 0 sind. 
Sind alle Koordinaten gleich null, ist der Zielknoten der 
Daten erreicht. 

b. Dynamisches Verfahren. Die Daten werden beliebig in eine 
der moglichen Richtungen bewegt, wobei die Bewegung immer in 
die vom Richtungsvektor vorgegebene Richtung erfolgt. Dabei 
bedeutet eine beliebige Bewegung, dafl die Daten immer zu dem 
Knoten weitergeleitet werden, zu dem am wenigsten Verkehr 
herrscht. Es wird also versucht immer den Weg der geringsten 
Kollisionen und Blockaden zu gehen. Dadurch kann das Verfahren 
u.U. schneller und bei grofien Systemen geeigneter sein. 

2. Adress-Lookup 

Werden Lookup-Adressen ubertragen, wird der jeweils nachste 
Knoten in jedem Knoten neu bestimmt. Dies geschieht indem in 
den nachfolgend beschriebenen Routingtabellen der Eintrag der 
Lookup-Adresse ausgelesen wird und so die Daten fur das 
nachste Ziel festgelegt werden. Dieses Ablauf ist gleich wie 
im "gewdhnlichen" Routing-Verf ahren. 
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Der Vorteil der Raumkoordinaten liegt darin, daft kein Lookup 
in einer Tabelle benotigt wird und somit weniger 
Verwaltungsaufwand anfallt. 

Der Vorteil des Adress-Lookup liegt in seiner Flexibilitat und 
der genauen Vorhersagbarkeit der Verbindung. 

Teilweise kann es sinnvoll beide Verfahren miteinander zu 

mischen. Dazu mussen beide Adressen (Raumkoordinaten und 

Lookup-Adressen) gleichzeitig ubertragen werden. 

Sind die Raumkoordinaten nicht null, werden die Daten anhand 

der Raumkoordinaten ubertragen. Sobald die Raumkoordinaten 

null erreichen, wird in der aktuellen Routingtabelle ein 

Lookup an Stelle der Lookup-Adresse durchgef uhrt . 

Dadurch ist flexibel einstellbar iiber welchen Segmenten . die 

Daten per Lookup-Verf ahren oder Raumkoordinaten-Verf ahren 

ubertragen werden. 

Die Buszustande des erweiterten Routingverf ahrens 
1. Quasi-permanent 

Eine Verbindung kann ahnlich zum "gewohnlichen" 
Routingverf ahren quasi-permanent aufgebaut werden. Dabei wird 
jeder Knoten, den ein erstes Datum durchlauft permanent gemaft 
den Adressen die die diesem Datum zugeordnet sind 
freigeschaltet. Die Freischaltung bleibt fur alle 
nachfolgenden Daten so lange auf rechterhalten, bis ein Abbruch 
der Verbindung durchgef uhrt wird. Obwohl ein derartiger Aufbau 
im erweiterten Routingverf ahren nicht zwingend notwendig ist, 
bietet er zwei Vorteile: 

i. Die Durchlauf zeit der Daten wird erheblich verringert. 
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ii. Zeitverluste durch Arbitrierung werden vermieden. 

2. Registered 

Dies ist der normale Buszustand. Eingehende Daten werden 
zunachst in einem Register zwischengespeichert . Beim Schreiben 
in das Register, wird ein Quittierungssignal an den sendenden 
Knoter. geschickt. Daten werden nur in das Register 
geschrieben, wenn dieses leer ist, d.h. entweder vorher keine 
Daten in das Register geschrieben wurden oder die vorher 
geschriebenen Daten bereits weiterubertragen sind. Ist das 
Register nicht leer, wird so lange gewartet und kein 
Quittierungssignal erzeugt, bis das Register leer ist. Die 
Register werden arbitriert und das Register mit der momentan 
hochsten Prioritat wird ubertragen. Die Arbitrierung und 
Ubertragung findet zyklisch mit jedem Takt statt. Diese 
Methode eignet sich vor allem fur Obertragungskanale auf denen 
Daten vieler verschiedener Quellen zeitunkritisch ubertragen 
werden mussen. Diese Methode wird quellenoptimiert genannt. 

3. Segmentiert 

Ein segmentierter Obertragungskanal besteht aus quasi- 
permanenten und register-orientierten Knoten. Dabei ist der 
Obertragungskanal stellenweise geschwindigke'itsoptimiert 
quasipermanent und an anderen Stellen quellenoptimiert 
ausgestaltet. 
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Die Routingtabellen 

Grundbaustein eines Knotens ist eine Routing-Tabelle, ahnlich 
der in DE 196 54 846.2-53 beschriebenen Switching-Tabellen . 

Der mogliche Aufbau einer solchen Tabelle ist wird anhand 
eines Ausfiihrungsbeispieles beschrieben: 





Tor 


EALU 


Bus 


Eintrag 
Position 
in 

Zieltabel 
le 


Lauf zeit 


Aufbauzeit 


1 


2 


3 


4 


0 
1 


0 
2 


R 
1 


R 
2 


1 


0 


a. . 0 


b. .0 


c. .0 











































































































Jede Zeile stellt eine gultige Verbindung dar. Dabei konnen 
mehrere Verbindungen gleichzeitig aktiv sein, maximal so viel 
Verbindungen, wie freie interne Sammelschienen und freie 
externe Bussegmente existieren. Eine nachfolgend beschriebene 
Oberwachungslogik ubernimmt die Prufung, ob eine neu 
ausgewahlte Verbindung aufgebaut werden kann. 
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Jede Zeile wird iiber ihre binare Adresse angesprochen und 
ausgewahlt. Weiterhin gibt es Sonderzeilen, die keine binare 
Adresse besitzen, sondern iiber Triggerssignale oder 
Zustandssignalen selektiert werden. Zu diesen Signalen gehbren 
(vgl. DE 196 51 075.9-53) 

- rRDYl, rRDYh 

- OACK1, OACK2 

Hierbei werden Busverbindungen zu den Datenempf angern (rRDY) 
automatisch immer dann aufgebaut, wenn die Datensender-Zelle 
giiltige Ergebnisse besitzt. Bei den Signalen oACK ist der 
Empfanger-/Senderablauf vertauscht. Der Datenempf anger baut 
die Verbindung zu seinem Datensender auf, sobald der 
Datenempfanger seine Operanden abgearbeitet hat und in der 
Lage ist neue Operanden zu verarbeiten. 

In den Spalten Tor werden die fur die jeweilige Verbindung 
aktiven Tore eingetragen, dabei ist es mbglich, daft nur ein 
Tor markiert ist und in den Spalten EALU eine Verbindung zu 
einem konf igurierbaren Element (einer oder mehrerer Zellen) 
zum Beispiel zu einem R-REG oder O-REG (vgl. DE 196 51 075.9- 
53) gewahlt wird. 

In der Spalte Bus wird die fur diese Verbindung verwendete 
interne Sammelschiene ausgewahlt, dabei ist der Wert binar, so 
daft in der beschriebenen Tabelle insgesamt 4 interne 
Sammelscheinen benutzt werden konnnen. Die Auswahl der 
internen Sammelschienen kann auch entfallen, in dem ein 
Prioritatsdekoder die erste freie Sammelschiene erkennt und 
diese automatisch zuteilt. 
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In der Spalte Eintrag Position in Zieltabelle wird die Adresse 
der Zeile der Tabelle angegeben, die den Knoten steuert, zu 
dem Verbindung aufgenommen wird. An dieser Adresse stehen die 
far die aktuelle Verbindung benotigten Routinginf ormationen im 
nachsten Knoten. 

Die Spalte Laufzeit ist optional. Darin kann die erwartete 
Signallauf zeit vom DS zum DE angegeben werden. Diese 
Information kann fur Berechungen des Datendurchsatzes oder zur 
Generierung eines Timeout verwendet werden. 

Die Spalte Aufbauzeit ist optional. Darin kann die maximale 
Zeit zum Aufbauen der Verbindung zum nachsten Knoten (oder der 
gesamten Verbindung vom DS zum DE) angegeben werden. Wird 
diese Zeit uberschritten kann iiber einen Timeout der 
Verbindungsaufbau abgebrochen werden und die Bussegmente und 
Knoten werden fur andere Verbindungen frei. 
Zu einem spateren Zeitpunkt versucht der DS erneut die 
Verbindung herzustellen . 

Die Eintrage in der Routingtabelle konnen gemaJJ bekannten 
Verfahren (DE 196 51 075.9-53, DE 196 54 846.2-53) von einer 
Ladelogik konfiguriert und umkonf iguriert werden. 

Wird das "erweiterte" Routingverf ahren verwendet, mussen die 
Raumkoordinaten den Routingtabellen hinzugefiigt werden. 
Ebenfalls wird eine Prioritatskennung erwartet. 
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Die Prioritatskennung gibt Auskunft, wie relevant ein Kanal 
fur die Leistung eines Bausteines ist. 1st die 
Prioritatskennung sehr hoch, steigt die Relevanz des Kanales. 
Dabei kann die Kennung auf drei Arten ausgelegt werden: 

1 . Timeout 

Die Kennung gibt an, nach wievielen ungenutzten Taktzyklen der 
Kanal abgerissen werden soil, also nach wievielen Zyklen eine 
DISCONNECT generiert wird. 

2. Paket-Grofte 

Die Kennung gibt an, nach wievielen Datenpaketen ein 
DISCONNECT generiert wird. 

3. Takt-Zyklen 

Die Kennung gibt an, nach wievielen Taktzyklen ein DISCONNECT 
generiert wird. 

Dabei kann fest eine der 3 moglichen Arten implementiert 
werden, oder mittels einer zusatzlichen Angabe eine Art 
ausgewahlt werden. 



Die Prioritatsart (Prioart in der nachstehenden Tabelle) wird 
in der nachfolgen beispielsweise aufgefuhrten Routingtabelle 
wie folgt ausgewertet: 



Bit-Kombination 


Prioritatsart 


00 


Timeout 


01 


Paket-Grolie 


10 


Takt-Zyklen 


11 


permanent 
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Permanent kann auch dargestellt werden, indem ein Wert der 
Prioritatskennung fest als "permanent" vorgegeben ist. Dafur 
eignet sich fur gewohnlich besonders der Maximalwert der 
Prioritatskennung oder null. 





Tor 
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Bus 


Eintrag 
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koordinate 

und 
Richtungs- 
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0 
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R 
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k. . 0 


m. . 0 


n. . 0 
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Der Arbiter 

Der Routingtabelle vorgeschaltet ist ein Arbiter, die aus der 
Menge der Anfragen zum Verbindungsaufbau iiber die 
Routingtabelle einige Signale auswahlt. Dabei ist es sinnvoll 
den Arbiter aus einem gewdhnlichen Priority-Logik und einem 
sogenannten Round-Robin-Arbiter nach dem Stand der Technik (er 
schaltet die hochste Prioritat auf einer Zeitscheibe immer dem 
nachsten Signal zu, das bedeutet, das Signal, das momentan die 
hSchste Prioritat hat, wird als nachstes die Niederste 
besitzen und dann mit jedem Zugriff eine Hohere erhalten) 
aufzubauen. Dabei kann die Priority-Logik dazu dienen einigen 
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Signalen, wie zum Beispiel rACK, oRDY grundsatzlich eine 

besonders hohe oder besonders niedere Prioritat 

zuzuordnen. Der Round-Robin-Arbiter sorgt dafur, dafi ein 
angeforderter Verbindungsaufbau, der soeben nicht aufbaubar 
war, die niederste Prioritat erhait und somit wartet, bis alle 
anderen Verbindungsanforderungen entweder aufgebaut oder 
uberpriift wurden. 

Die Zustandsmaschine (Steuerung) 

Eine Zustandsmaschine steuert die internen Ablaufe im Knoten. 
Dabei ist die Zustandsmschine zweigeteilt: 

- Die Steuerung des Knotens 

- Die Steuerung des Bustransfers und der Synchronistation . 
Dabei kann auf eine Zustandsmaschine ahnlich der in DE 196 51 
075.9-53 beschriebenen zuriickgegrif f en werden. 

Die Zustandsmaschine (n) sind gemafi dem Stand der Technik 
implement ierbar und werden nicht nahers beschrieben. 

Die Uberwachungseinheit 

Eine Uberwachungseinheit ist der Routingtabelle 
nachgeschaltet . Sie entnimmt die in eine adressierte Zeile 
eingetragenen Daten und uberpriift ob der Verbindungsaufbau 
moglich ist. 

Dabei werden vor allem folgende Punkte uberpriift: 

- Steht eine freie interne Sammelschiene zur Verfugung. 

- Ist das angeforderte Tor frei. 
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- 1st das angeforderte externe Bussegment frei. 

a) 1st die Oberprufung positiv, wird das Signal ACCEPT 
generiert und an die Zustandsmaschinen, sowie die, den 
Verbindungsaufbau anfordernde Einheit, gesendet, urn einen 
erf olgreichen Aufbau zu signalisieren . 

b) 1st die Oberprufung negativ, wird das Signal REJECT 
generiert und an die Zustandsmaschinen, sowie die, den 
Verbindungsaufbau anfordernde Einheit, gesendet, um einen 
fehlgeschlagenen Aufbau zu signalisieren. Auf dieses Signal 
kann der oben beschriebene Arbiter reagieren und die Prioritat 
dieser Anforderung auf die Niederste setzen. 

Verbindungsabbau 

Eine bestehende Verbindung kann durch verschiedene Kriterien 
wieder abgebaut werden. Zu den wichtigsten Kriterien zahlen: 
Timeout: Eine Verbindung wird abgebaut, da uber eine langere 
Zeitspanne kein Datentransf er stattgefunden hat. Ein Timeout 
kann einfach Uber einen ladbaren Abwartszahler implementiert 
werden. Der Zahler wird bei jedem ubertragenen Datum neu mit 
einem festen Ausgangswert, der die Zeitspannne bis zum Timeout 
reprasentiert, geladen. Findet kein Datentransf er statt, zahlt 
er mit jedem Bustakt um eins herunter. Kommt er bei null an, 
ist die maximale Zeitspanne abgelaufen und der Bus wird 
abgebaut. 

Datenzahler: Ein ladbarer Zahler wird mit der zu ubertragenden 
Anzahl von Daten geladen. Bei jedem Datentransf er zahlt der 



19 



WO 98/35294 



PCT/DE98/00456 



Zahler um eins herab. Kommt der Zahler bei null an, sind alle 
Daten ubertragen und der Bus wird abgebaut. 

Synchronisationssignale (vgl. DE 197 04 728.9, RECONFIG) : Der 
Busabbau wird durch die Status- und/oder 
Synchronisationssignale der Zelle(n) gesteuert, die als 
Datensender auftreten. Zeigen die Zellen beispielweise an, daft 
ihre Datenverarbeitung beendet ist oder daft sie umkonf iguriert 
werden konnen, wird der Bus abgebaut, da er nicht mehr 
ben5tigt wird. Zu diesen Signalen gehoren auch rRDY, oACK. 

Der Verbindungsabbau geht dabei so vonstatten, daft vom 
Initiator-Knoten aus ein Signal zum Abbauen der Verbindung 
gesendet wird Jeder weitere Knoten sendet das empfangene 
Signal an seine (n) Partnerknoten weiter und lost die 
Verbindung sofort auf. 

Im erweiterten Routingverf ahren werden quasi-permanente Busse 
entweder durch das RECONFIG-Synchronisationssignal (vgl. DE 
197 04 728.9) oder gemaft der Prioritatskennung abgebaut. Wird 
das Ende einer Verbindung gemaft der Prioritatskennung von 
einem Knoten f estgestellt, wird von ihm das DISCONNECT-Signal 
zum Abbruch des Busses generiert und an alle anderen Knoten 
weitergeleitet . Die Knoten reagieren auf ein DISCONNECT wie 
auf ein RECONFIG. 

Bei register-orientierten Knoten ist ein Verbindungsabbau 
nicht notwendig, da eine Verbindung dynamisch mit den 
eintref f enden Daten gemaft der zugeordneten Adressen aufgebaut 
wird. Nach dem Weiterleiten der Daten ist die Verbindung 
automatisch abgebaut und fur andere Obertragungen frei. 
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Broadcasting 

In DE 196 51 075.9-53 ist ein Bussystem beschrieben, das das 
Senden eines Datenpaketes an mehrere Empfanger erlaubt und 
ebenfalls eine Quittierung des Datentransf ers ermoglicht. 
Dasselbe System kann bei dem hier beschriebenen Verfahren 
verwendet werden. Es ist ohne weiteres moglich, mehrere Tore 
auf eine Sammelschiene zu schalten. Dabei wird nur eine Zeile 
in der Routingtabelle verwendet. Die Adresse innerhalb der 
Zielroutingtabellen Eintrag Position in Zieltabelle muli dabei 
bei jeder der selektierten Routingtabellen zwangslaufig 
dieselbe sein. 

Urn dieses Problem zu umgehen, ist es moglich mehrere Eintrage 
fur als Eintrag Position in Zieltabelle zur Verfugung zu 
stellen. Beispielsweise konnte fur jedes Tor ein separater 
Eintrag Position in Zieltabelle existieren. Damit ist jedem 
Tor eine Adresse innerhalb der Zielroutingtabelle zugeordnet. 

Die Quittierung erfolgt genau wie in DE 196 51 075.9-53 
beschrieben iiber Signalleitungen, die von Open-Kollektor- 
Treiber getrieben werden und mit einem Transistor 
abgeschlossen sind. 

Um eine bessere Implementierbarkeit in existierende Chip- 
Technologien zu ermoglichen konnen Quittierungssignale in 
einem Knoten zunachst maskiert und danach logisch miteinander 
verknupft werden. Die logische Verkniipfung wird an den 
nSchsten Knoten weitergeleitet . Findet beispielsweise in alien 
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durchlaufenden Knoten eine logische UND-Verknupfung der 
Quittierungssignale statt, ist das Resultat dasselbe, wie bei 
einer Open-Kollektor-Schaltung. 

Ladelogik (PLU) 

Eine Ladelogik im Sinne von DE 44 16 881 Al ist an die 
Routingtabelle angeschlossen. Ober diese kann die 

Routingtabelle Equivalent zu den Switchingtabellen aus DE 

196 54 846.2-53 konfiguriert und umkonf iguriert werden. 

Die Routingtabellen konnen um eine Spalte erweitert werden, 
die benutzt wird um Ruckmeldungen an die Ladelogik zu senden, 
wenn die in der betreffenden Zeile angegebene Verbindung auf- 
oder abgebaut wird. So kann in der Spalte angegeben werden, ob 
eine Riickmeldung an die PLU erfolgen soil, wenn die Verbindung 
auf- oder abgebaut wird, sowie welcher Art die Riickmeldung 
ist. Die Riickmeldung erfolgt gemali DE 196 51 075.9-53 Figur 
15, wobei statt des Latches 1504 ein Tor eingeseczt ist, das 
je nach Einstellung entweder beim Verbindungsauf bau oder - 
abbau durchschaltet und die Riickmeldung an die Transistoren 
(1502), die als Open-Kollektor-Treiber geschaltet sind 
ansteuern. 
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Kurzbeschreibung der Diagramme 

Fig. 1 Zeigt einen zweisimensionalen Baustein mit Zellarray 
und Knoten. 

Fig. 2 Zeigt einen Ausschnitt aus Fig. 1. 

Fig. 3 Zeigt mehrere bestehende Busverbindungen und den Aufbau 
neuer Verbindungen. 

Fig. 4 Zeigt den Aufbau neuer Busverbindungen. 

Fig. 5 Zeigt den nachsten Schritt des Verbindungsauf baus . 

Fig. 6 Zeigt die Kollistion zweier Busse. 

Fig. 7 Zeigt den schrittweisen Verbindungsabbau nach einer 
Kollision. 

Fig. 8 Zeigt den schrittweisen Verbindungsabbau nach einer 
Kollision. 

Fig. 9 Zeigt den schrittweisen Verbindungsabbau nach einer 
Kollision. 

Fig. 10 Zeigt den schrittweisen Verbindungsabbau nach einer 
Kollision. 
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Fig. 11 Zeigt den Neuaufbau der abgebauten verbindung nach 
einer gewissen Zeitspanne. 

Fig. 12 Zeigt die Fortsetzung von Fig. 6, wenn der Knoten mehr 
als eine Sammelschiene besitzt und somit keine Kollision 
stattf indet . 

Fig. 13 Zeigt die Verbindung der Bussegmente mit den 
Sammelschienen eines Knotens. 

Fig. 14 Zeigt den Datentransf er eines Verbindungsaufbaus . Die 
Unterfiguren zeigen den Zustand der Verbindung jeweils im 
Abstanden von einem Buszyklus. 

Fig. 15 Zeigt den Datentransf er eines Verbindungsabbaus . Die 
Unterfiguren zeigen den Zustand der Verbindung jeweils im 
Abstanden von einem Buszyklus. 

Fig. 16 zeigt die Steuereinheit eines Knotens. 

Fig. 17 Zeigt das Broadcasting an mehrere Datenempf anger . 

Fig. 18 zeigt eine gegenuber Figur 16 verbesserte 

Steuereinheit eines Knoten mit Kollisionsdetektoren . 

Fig. 19 zeigt eine gegenuber Fig. 16 verbesserte 

Routingtabelle mit Ansteuerung der Fig. 18. 

Fig. 20 zeigt die zu Fig. 18/19 passenden Sammelschienen. 

Fig. 21 zeigt ein gegenuber Fig. 17 verbessertes Broadcasting 

an mehrere Knoten. 

Fig. 22 zeigt die Ablauf steuerung der Fig. 18-21. 
Fig. 23 zeigt einen Busknoten gemaJi dem erweiterten 
Routingverf ahren . 

Fig. 24 zeigt eine optimierte Variante von Fig. 23. 
Fig. 25 zeigt ein Datenregister mit Synchronisationseinheit . 
Fig. 26 zeigt einen Kollisionsdetektor nach dem erweiterten 
Routingverf ahren . 
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Fig. 27 zeigt die Steuereinheit fur Fig. 23-26. 

Fig. 28 zeigt einen durchsatzsteigernden, kaskadierbaren 

Zusatz zu Fig. 27. 

Fig. 29 zeigt die Steuerregister fur Fig. 27 (2705) . 

Fig. 30 zeigt einen Busaufbau uber relative Raumkoordinaten 

gemaJJ dem erweiterten Routingverf ahren . 

Fig. 31 zeigt einen Busaufbau uber absolute Raumkoordinaten 

gemafi dem erweiterten Routingverf ahren. 

Fig. 32 zeigt die Verwaltung der Raumkoordinaten. 

Fig. 33 zeigt einen segmentierten Busaufbau. 

Detailbeschreibung der Diagramme 

Figur 1 zeigt einen Baustein der Gattungen FPGA, DPGA, DFP (DE 
44 16 881 Al) . Der Baustein ist zweidimensional symmetrisch 
aus konfigurierbaren Zellen (0101) aufgebaut, dabei kann 0101 

auch eine Mehrzahl von auch unterschiedlichen 

konfigurierbaren Zellen, die zu einer Gruppe zusammengef aiit 
und untereinander vernetzt sind, reprasentieren . Zwischen den 
Zellen befinden sich die Knoten des Bussystemes (0102). Dabei 
sind mehrere Knoten gekennzeichnet, die im folgenden 
Ausfuhrungsbeispiel mehrere Verbindugnen aufbauen werden. Der 
Datensender A (0103) wird im Folgenden eine Verbindung zum 
Datenempf anger A (0104) aufbauen, sowie der Datensender B 
(0106) mit dem Datenempf anger B (0105) . Eine ausschnittsweise 
Vergrolierung (0107) ist in Fig. 2 dargestellt. 
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Figur 2 zeigt einen Ausschnitt aus einem Baustein 
beschriebener Gattung. Die konf igurierbare (n) Zelle(n) aus 
Fig. 1 (0101) sind in 0201 dargestellt. Ein Biindel (0203) aus 
einer Vielzahl von Leitungen (die Anzahl ist beliebig und 
nicht exakt dargestellt) verbindet 0201 mit einem Knoten 0202. 
Die Knoten (0202) sind uber die Bussegmente (0205) miteinander 
verbunden. Ebenfalls haben die Knoten uber die Bussegmente 
0206, deren Ausgestaltung dieselbe wie die der Bussegmente 
0205 ist, Anschluli an die sich auilerhalb der Vergroilerung 
befindenden Knoten. Ober das optionale Leitungsbiindel (0204) 
wird verdeutlicht, dafl die konf igurierbare (n) Zelle(n) auch 
tiber mehrere unterschiedliche Leitungsbundel an eine Mehrzahl 
von Knoten (0202) angeschlossen sein kann/konnen. 

Figur 3 zeigt den Baustein zur Laufzeit. 
Es existieren mehrere Verbindungen : 

- zwischen den Knoten Z (0301) 

- zwischen den Knoten Y (0306) 

Der Datensender A (0302) versucht eine Verbindung (0303! zum 
Datenempf anger A (0307) aufzubauen. Die Verbindung wird jedoch 
zuriickgewiesen (REJECT), da sie beim Knoten Z (0308) blockiert 
ist. Gleichzeitig baut der Datensender B (0304) ein Bussegment 
(0305) zu seinem Empfanger auf. Dieser Versuch gelingt, da der 
angesprochene Knoten und das bendtigte Bussegment nicht 
blockiert ist. 

Figur 4 zeigt den nachsten Buszyklus. Die Verbindungen Y und Z 
sind zwischenzeitlich abgebaut. Der Datensender A (0401) kann 
nun das Bussegment (0403) aufbauen, da der Knoten (0402) nicht 
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mehr blockiert ist Gleichzeitig baut der Datensender B (0404) 
das bereits bestehende Bussegment (0405) iiber den Knoten 
(0406) hinaus aus => Das neue Bussegment (0407) wird 
aufgebaut . 

Figur 5: Der in Fig. 3 begonnene und iiber Fig. 4 fortgesetzte 
Busaufbau setzt sich aquivalent zu Fig. 4 fort. 

Figur 6: Der Verbindungsaufbau des Bussegmentes 0602 des 
Datensenders B schlagt fehl. Der Knoten 0601 ist besetzt und 
liefert ein REJECT-Signal, das das Fehlschlagen des 
Verbindungsaufbaus signalisiert und den Abbruch der Verbindung 
bewirkt, an den Knoten 0603. 

Figur 7 zeigt den kompletten Verbindungsaufbau zwischen dem 
Datensender A (0701) und dem Datenempf anger A (0702). Die 
Verbindung des Datensenders B wird weiter abgebaut. Der Knoten 
0703 liefert iiber das Bussegment (0704) das REJECT-Signal an 
den Knoten 0705. Daraufhin wird das Segment 0704 abgebaut. 

Figur 8: Der Datentransf er zwischen dem Datensender A und dem 
Datenempf anger A beginnt. Die Verbindung des Datensenders B 
wird weiter abgebaut. Der Knoten 0801 liefert iiber das 
Bussegment (0802) das REJECT-Signal an den Knoten 0803. 
Daraufhin wird das Segment 0802 abgebaut. 

Figur 9: Der Datentransf er zwischen dem Datensender A und dem 
Datenempf anger A setzt sich fort. Das letzte Segment des 
Datensenders B wird abgebaut. Der Knoten 0901 liefert iiber das 
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Bussegment (0902) das REJECT-Signal an den Knoten 0903. 
Daraufhin wird das Segment 0902 abgebaut. 

Figur 10: Der Datentransf er zwischen dem Datensender A und dem 
Datenempfanger A setzt sich fort. Der Datensender B (1001) 
wartet eine Zeitspanne ab, bis er erneut versucht eine 
Verbindung zu seinem Datenempfanger aufzubauen. 

Figur 11 zeigt den Zustand mehrere Buszyklen spater: Der 
Datentransf er zwischen dem Datensender A und dem 
Datenempfanger A findet immer noch statt. Der Datensender B 
(1101) startet einen neuen Versuch die verbindung zu seinem 
Datenempfanger aufzubauen. Er baut ein Bussegment (1102) zum 
Knoten (1103) auf. Sofern in den nachsten Buszyklen die 
Verbindung des Datensenders A zu seinem Datenempfanger A 
abgebaut ist, gelingt der Verbindungsaufbau des Datensenders B 
(1101), ansonsten schlagt sie wie in Fig. 6 beschrieben erneut 
fehl. 

Figur 12 zeigt die Fortsetzung der Fig. 6, wenn der Knoten 
1202 in der Lage ist mehr als eine Verbindung aufzubauen, das 
heiJlt, der Knoten besitzt mehrere interne Sammelschienen . 
Dadurch kann die Verbindung des Datensenders A uber die erste 
Sammelschiene abgewickelt werden und die Verbidnung des 
Datensenders B uber die Zweite. Der Knoten 1202 baut das 
Bussegment 1203 zu dem Datenempfanger B (1201) auf. 

Figur 13 stellt eine knoteninterne Vernetzungsstruktur dar. Es 
existieren vier knoteninterne Sammelschienen 1301, 1302, 1303, 
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1304. Ober je eine Gruppe von Toren (1308, 1309, 1310, 1311) 
werden die Sammelschienen auf die Bussegmente Westen (1318), 
Norden (1316), Osten (1319), Suden (1317) geschaltet. Ober die 
Tore 1307 werden die Sammelschienen mit den O-REGl/2 (vgl. DE 
196 51 075.9-53) verbunden (1314, 1315). Uber die Tore 1306 
wird das R-REG (vgl. DE 196 51 075.9-53) auf die 
Sammelschienen geschaltet. Dabei kann das niederwertige und 
hoherwertige R-REG (1312, 1313) jeweils getrennt verschaltet 
werden. Die Tore werden iiber den Bus 1320 angesteuert. Dabei 
wird das benotigte Torsystem (Westen, Norden, Osten, Suden) , 
sowie die interne Sammelschiene angegeben. Durch VerUNDung 
(1325, 1326, 1327, 1328) der Richtungsangabe mit der Angabe 
der selektierten Sammelschiene wird das erf orderliche Tor 
(1321, 1322, 1323, 1324) ausgewahlt. 

Figur 14a zeigt den Aufbau einer Verbindung, dabei ubermittelt 
der Datensender (1401) dem Knoten des Datensenders (1402) das 
erste Datenpaket. 

Figur 14b Der Knoten selektiert dabei aus der Routingtabelle 

den zu rRDY rRDY ist ein Statussignal , das anzeigt, daB 

Daten am Datensender bereitstehen (vgl. DE 196 51 075.9-53) — 
- gehdrenden Eintrag. Anhand diesem Eintrag wird das nachste 
Bussegment aufgebaut und die Adresse der Routingtabelle des 
nachsten Knotens ubertragen. 

Figur 14c Der letzte Knoten (1403), der Datenempf angerknoten, 
erhalt die Adresse fur den Eintrag innerhalb seiner 
Routingtabelle. Der Eintrag zeigt auf keinen weiteren Knoten, 
sonderen auf eine Zelle. Daher aktiviert der Knoten sofort 
seine Tore zur selektierten Zelle. 
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Figur 14d Die Daten gelangen durch das aktivierte Tor von 1403 
direkt zur Empfangerzelle 1404. 

Figur 14e Die Zelle sendet das oACK-Signal (vgl. DE 196 51 
075.9-53) als Quittierung fur die erhaltenen Daten zuruck. Im 
nachsten Buszyklus (vgl. Fig. 14e) wird der Datensender 
daraufhin das nachste Datenpaket absenden. 

Figur 14e-g Der normale Datenaustausch zwischen den Zellen 
lauft ab. 

Figur 15a Es existiert eine Datenverbindung vom Datensender 
(1501) zum Datenempfanger (1503) uber mehrere Knoten. 
Figur 15b Der Datensender (1501) hat seine Datenubertragung 
beendet und sendet ein DISCONNECT-Signal zum ersten Knoten. 
Figur 15c Das erste Bussegment ist abgebaut und der Knoten 
reicht das DISCONNECT-Signal weiter. 
Figur 15d Der Verbindungsabbau geht weiter. 

Figur 15d Der letzte Knoten erhalt das DISCONNECT. Daraufhin 
baut der letzte Knoten gleichzeitig die Verbindung zum 
Vorganger knoten und zum Datenempfanger ab. 
Figur 15e Das letzte Bussegment und die Verbindung zum 
Datenempfanger ist abgebaut. 

Figur 15f zeigt das ein Abbauverf ahren, bei dem die 
DISCONNECT-Leitung durch alle Knoten durchgeschleif t ist. 
Dabei wird das DISCONNECT in einem Taktzyklus propagiert; alle 
Segmente werden gleichzeitig abgerissen. 
Figur 15g entspricht Figur 15e. 

Figur 16 Zeigt die Steuerung eines Knotens. Die Anf orderungen 
(1601) zum Aufbau einer Verbindung gelangen iiber den 
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Prioritatsdekoder (1602) an die Routingtabelle (1603). Der 
Prioritatsdekoder wahlt die Anforderung mit der hochsten 
Prioritat aus, wobei eine soeben f ehlgeschlagene Anforderung 
die niederste Prioritat zugewiesen bekommt. Die 
Prioritatslogik erhalt Ihre Anf orderungen iiber Statussignale 
(z.B. der der konf igurierbaren Zellen (vgl. DE 196 51 075.9- 
53) rRDY, oACK) oder uber die Bussegmente 1316, 1317, 1318, 
1319. Liegen Daten an den Bussegmenten an, ohne daB das Tor 
des Bussegmentes aktiviert ist, werden die Daten von der 
Prioritatslogik als Adresse der Routingtabelle interpretiert 
und als Anforderung betrachtet. Liegen Statussignale an der 
Prioritatslogik an (rRDY, oACK) , werden diese in Adressen fur 
die Routingtabelle ubertragen. Die Adressen der Routingtabelle 
selektieren einen Eintrag. Die Daten des Eintrages (1604) 
werden an eine Einheit aus UND-Gattern (1605) weitergeleitet . 
Dabei wird die Binarzahl der Busauswahl (BUS 1..0) uber einen 
2:4 Dekoder (1606) in Selektsignale ubertragen. Die UND- 
Gatter-Einheit verUNDet dabei jedes Signal mit demselben in 
einem Latch (1607) gespeicherten Signal. Das heiBt daft das 
Signal GAT El der Routingtabelle mit dem Signal GAT El des 
Latches verUNDet wird, das Signal GATE 2 der Routingtabelle mit 
dem Signal GATE 2 des Latches und so weiter. Dabei 
reprasentieren die Signale des Latches den Zustand der 
momentan aktuellen Vernetzungsstruktur, d.h. die benutzten 
Tore und die benutzten Sammelschienen sind in das Latch 
eingetragen. Ergibt eine VerUNDung der Verbindungsanf orderung 
mit dem aktuellen Zustand einen wahren Pegel, bedeutet dies, 
daB die neue Verbindungsanf orderung Ressourcen benotigt, die 
momentan benutzt sind. Uber ein ODER-Gatter (1608) werden alle 
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UND-Gatter miteinander verknupft. Ergibt sich am Ausgang des 
ODER-Gatters ein wahrer Pegel, wird die Verbindungsanf orderung 
zuruckgewiesen (REJECT) (1609), da die benotigten Ressourcen 
belegt sind. Aus dem REJECT-Signal wird tiber einen Inverter 
(1610) das ACCEPT-Signal (1611) generiert. Die Signale 
werden an eine Zustandsmaschine (1612), die nach dem Stand der 
Technik implementiert sein kann, weitergeleitet . Diese steuert 
danach die Annahme der Verbindung oder die Zuruckweisung. Wird 
die Verbindungsanf orderung zuruckgewiesen, meldet (1613) die 
Zustandsmaschine den REJECT an den Prioritatsdekoder und die 
Anf orderung erhalt niederste Prioritat. Bei einer Annahme der 
Anforderung, werden die neuen Zustandssignale mit den 
aktuellen Zustandssignalen nach dem Latch verODERt (1614) — 
dabei ist die ODER-Einheit ebeso aufgebaut wie die 

beschriebene UND-Einheit (1605) und in das Latch (1607) 

zuriickgeschrieben. Uber 1623 steuert die Zustandsmaschine, ob 
die ODER-Einheit (1614) oder die Maske (1616) aktiv ist. Das 
Latch wird uber 1622 von der Zustandsmaschine getriggert. Uber 
den Bus 1615 gelangt die neue Einstellung an die Tore. 

Der Abbau einer Busverbindung lauft auf ahnliche Weise. 
Allerdings findet muli bei einer Uberprufung der Ressourcen das 
Signal REJECT auftreten, da die Busverbindung, die abgenbaut 
werden soil, existieren mufi. Aufgrund des REJECTS aktiviert 
die Zustandsmaschine 1612 anstatt der ODER-Einheit 1614 die 
Maske 1616. Die Verbindungsdaten der abzubauenden Verbindung 
werden aus dem aktuellen Vernetzungszustand ausmaskiert und in 
das Latch 1607 zuriickgeschrieben. Vor dem Zurtickschreiben der 
neuen verbindungsdaten sendet die Zustandsmaschine das 
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DISCONNECT-Signal zum Abbau der Verbindung an den nachsten 
Knoten. 

Ober die Tore 1617 , 1618, 1619, 1620 kann die Steuerung direkt 
auf die Sammelschienen 1301, 1302, 1303, 1304 zugreifen. Damit 
kann die Zustandsmaschine sowohl Steuersignale (DISCONNECT) 
auf die Sammelschiene tibertragen, als auch Steuersignale von 
der Sammelschiene erhalten (REJECT, ACCEPT) und auf diese 
reagieren. Ebenfalls dienen diese Tore urn den Eintrag Position 
in Zieltabelle (uber 1621) auf die Sammelschiene zu 
ubertragen. 

Uber 1624 kann die Ladelogik (PLU) auf die Routingtabelle 
zugreifen. 

Figur 17 Zeigt ein Broadcasting eines Datensenders (1701) an 
mehrere Datenempf anger (1702) uber eine Vielzahl von Knoten 
(1707), auf die nicht nahers eingegangen wird. Der Bus ist zur 
Verdeutlichung aufgetrennt dargestellt, namlich in die 
Quittierungsleitung (A'CK) (1703) und den restlichen Bus 
(1704). ACK wird dabei negiert und an den wiederum 
invertierenden Open-Kollektor-Bustreiber geliefert. ACK wird 
Uber einen PullUp-Widerstand 1705 auf H gezogen. Dabei ist die 
Schaltung so aufgebaut, daft folgende Falle eintreten: 

- Wird der entsprechende Bus nicht angesteuert, liegt an der 
Basis des Transistors (1706) L an. Dadurch belastet er den Bus 
nicht . 

- Wird der entsprechende Bus angesteuert, und das Signal nicht 
quittiert, liegt an der Basis des Transistors (1706) H an. Das 
bedeutet, daJi der Bus auf L gezogen wird. Wird ein Ergebnis 
per Broadcasting an mehrere Datenempf anger verteilt, so ziehen 
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alle Knoten, die die Ergebnisdaten noch nicht quittiert haben 
und Warte-Zyklen benotigen den Bus auf L. 
- Wird der entsprechende Bus angesteuert, und das Signal 
quittiert, liegt an der Basis des Transistors (1706) L an. Das 
bedeutet, dali der Bus nicht belastet wird. Wird ein Ergebnis 
per Broadcasting an mehrere Datenempf anger verteilt, so 
belasten alle Knoten, die die Ergebnisdaten quittiert haben 
und keine Warte-Zyklen benotigen, den Bus nicht. 
Da der Bus in seinem Grundzustand den H-Pegel, also die 
Quittierung, einnimmt, ubersteuert die Nichtquittierung gemali 
Fall 2 die Quittierung, indem sie den Bus auf L zieht. Dabei 
geht der Bus erst dann in den H-Pegel, also in den 
Quittierungszustand, wenn alle an der Verbindung beteiligten 
Knoten quittieren. Es ist somit eine Wired-AND-Schaltung 
realisiert . 



Im Folgenden ist ein Implemetierungbeispiel fur einen Knoten 
dargestellt, der den folgenden Busaufbau besitzt: 



Data 


Datensignale 


ACK 


Daten- und Aufbau-Handshake 


RDY 


Datenhandshake (Daten liegen an) 


ESTABLISH 


Aufbauhandshake (das Segment wird aufgebaut) 


DISCONNECT 


Aufforderung zum Busabbau (durch einen 
Timeout) 


RECONFIG 


Aufforderung zum Busabbau (durch 
Umkonf iguration der beteiligten 
konf igurierbaren Zellen) 
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Figur 18 zeigt die Ansteuerung von der Sammelschienen aus 
Figur 13. Im Gegensatz zu der bisher beschriebenen Losung, die 
Sammelschiene in den Routingtabellen vorzugeben, ist die Logik 
in der Lage eine freie Sammelschiene selbst festzustellen und 
zu allokieren. 

Je eine Ansteuereinheit 1801 ist einer Sammelschiene 
zugeordnet. Eine Ansteuereinheit besteht aus einem Tor 
(1801a), urn wahrend des Verbindungsaufbaus die 
Adressinformationen der Routingtabelle an die Sammelschiene 
angeschlossenen Knoten zu senden und einem Register (1801b), 
das die Ansteuerung der Sammelschiene ubernimmt. 1801 erhalt 
uber den Bus 1813 die Daten mittels einer in Figur 19 
beschriebenen Schaltung aus der Routingtabelle. Ober 1801b 
werden die Tore freigeschaltet, die Zugriff auf die 
entsprechend zugeordnete Sammelschiene haben. Jedes Tor 
besitzt eine Freischaltesignal, dem ein Eintrag in 1801b 
zugeordnet ist. Wenn kein Eintrag gesetzt ist, ist die 
zugeordnetet Sammelschiene unbelegt und kann frei einer 
Zugriff sanforderung zugeteilt werden. Die Oberprtifung wird 
durch eine ODER-Funktion (1802) uber alle Freischaltesignale 
an die Tore realisiert. Die Ergebnisse der 1802 aller 
Sammelschienen werden einem Arbiter (1803) zugefuhrt, der eine 
der freien Sammelschienen auswahlt und tiber einen Adressbus 
(1804) deren 1801 anspricht. Ist keine Sammelschiene frei, 
signaiisiert 1803 dies uber 1805 der steuernden Statemachine . 
Je ein Eintrag in 1801b kennzeichnet ein der Sammelschiene 
zugeordnetes Tor. Die Position ist in jedem 1801b dieselbe. 
Das bedeutet ab Position p eines 1801b befindet sich immer das 
Freischaltesignal fUr das Tor p, an Position p+1 das 
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Freischaltesignal fur Tor p+1 und an Position q das 
Freischaltesignal fur Tor q. Wird iiber die Freischaltesignale 
von je einem Tor p eine ODER-Funktion (1806) ausgefilhrt, gibt 
das Resultat an, ob Tor p frei ist oder nicht. Fur jedes Tor 
existiert eine derartige Oberpriifungsfunktion (1807 = Tor p+1, 
1808, 1809 = Tor q) . Ober eine Maske 1810 werden alle Tore, 
die fur den aktuellen Verbindungsaufbau irrelevant sind 
ausmaskiert, d.h. irrelevante Tore werden durch die Maske als 
nicht freigeschaltet weitergeleitet . Uber eine ODER-Funktion 
(1811) wird festgestellt ob eines der Tore freigeschaltet ist. 
Da alle irrelevanten Tore mit "nicht freigeschaltet" markiert 
sind, wird nur der Zustand des fur den aktuellen 
Verbindungsaufbau notwendigen Tores an die State-Machine 
weitergeleitet (1812) . Ist das gewiAnschte Tor freigeschaltet, 
kann es bei dem aktuellen Verbindungsaufbau nicht genutzt 
werden, da ansonsten eine Kollision eintreten wiirde. Der 
Verbindungsaufbau wird unterbrochen und entweder 
zuriickgewiesen oder zu einem spateren Zeitpunkt erneut 
versucht . 

In Figur 19 ist der Arbiter zur Auswahl des aktiven Busses und 
die Routingtabelle dargestellt. Jeder an einen Knoten 
angeschlossene Bus (2004, 2005, 2006) sendet seine 
Zugrif f sanforderung uber ein Signal (1901) an einen Arbiter 
(1902), der eine der Zugrif fsanforderungen auswahlt. Ober 
einen Dekoder (1903) wird der Multiplexer (1904) so 
angesteuert, dafi entweder die Nummer des ausgewahlten 
Zugriffes (bei direkten Zugriff durch eine konf igurierbare 
Zelle) (1905) oder die Lookup-Addresse des ausgewahlten 
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Zugriffes an die Routingtabelle 1906 ubertragen wird. 1906 
gibt die, dem Wert von 1905 zugeordneten, Daten aus. Die 
Lookup-Addresse fur den nachsten Knotens wird direkt iiber 1813 
an 1801a ubertragen. Die Adresse des nachsten Knotens wird 
dezimal auskodiert (1907) uber einen Mischer (1908), der fur 
gewohnlich aus ODER-Gattern ausgestaltet ist, mittels des 
Busses 1813 an 1801b ubertragen. Ist der Bus zum nachsten 
Knoten aufgebaut, wird die Freischaltung des Tores zum 
vorhergehenden Knoten ermoglicht, indem die iiber den 
Dezimaldekoder 1909 auskodierte Adresse des vorhergehenden 
Knotens im Mischer 1908 auf den Bus 1813 zugeschaltet wird und 
zu 1801b ubertragen wird. 

Figur 20 zeigt die Sammelschienen (2001, 2002, 2003) zur 
Aufschaltung der anliegenden Busse (2004, 2005, 2006) . Ober 
die Multiplexer/Demultiplexer (2007) werden die Busse gemali 
der Ansteuerung durch 1801b auf die Sairatielschienen geschaltet, 
dabei werden einem Multiplexer p die Ausgangssignale p aller 
1801b zugefuhrt, einem Multiplexer p+1 die Ausgangssignale p+1 
aller 1801b, etc. Die einzelnen Signale reprasentieren 
anlieger.de Sammelschienen, da jede Sammelschienensteuerung 
genau eines (p) aus einer Vielzahl von Signalen (p x ,p x +I, . . ,q x ) 
ansteuert. Ist ein zu einer Sammelschienensteuerung gehorendes 
Signal gesetzt, wird die entsprechende Sammelschiene durch 
einen 2007 auf geschaltet . 

Die Timeout-Generatoren (2008) steuern den Abbau des 
jeweiligen Segmentes und den auf geschalteten Bussen. Die 
Timeout-Generatoren werden direkt von der Routingtabelle 
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(1906) konfiguriert. Die Verbindung ist der Einfachheit halber 
in den Zeichnungen nicht dargestellt. 

Die einer jeweiligen Sammelschiene zugeordneten 1801a werden 
auf diese Sammelschiene auf geschaltet . 

In Figur 21 wird ein Bussegment (2105) uber einen Knoten 
(2101) an mehrere Knoten (2102, 2103, 2104) gebroadcastet . Das 
RDY-Handshake wird, ebenso wie die Daten direkt an jeden 
Empf anger gesendet. Uber die Masken (2105, 2106) werden die 
riicklaufigen ACK-Handshakes auf das ODER-Gatter (2107) und das 
UND-Gatter (2108) geschaltet. Uber die Masken wird dabei 
ausgewahlt, welches ACK signifikant ist, und ob ein ACK durch 
eine boolsche UND-Funktion Oder eine ODER-Funktion 
weitergeleitet wird. Beide Funktionen werden uber ein ODER- 
Gatter (2109) zusammengefalit. Ist ein ACK irrelevant, so gibt 
die Maske 2105 eine logische 0 (L-Pegel) weiter, wahrend die 
Maske 2106 eine logische 1 (H-Pegel) weitergibt. Die Masken 
2105 und 2106 werden getrennt von der Routingtabelle gesetzt. 
Die Verbindung ist der Einfachheit halber in den Zeichnungen 
nicht dargestellt. 

In Figur 22 ist die Statemachine der beschriebenen Schaltung 
dargestellt. 

Der Grundzustand ist "IDLE", den die Statemachine erst 
verlalit, wenn ein "request" (Zugriff) auftrat UND eine 
Sammelschiene UND das selektierte Tor frei sind. Dabei 
quittiert die Statemachine der vorhergehenden Statemachine den 
Busaufbau durch senden eines ACK-Handshakes. Die Statemachine 
geht in den SEND-Zustand, wahrend dessen die Daten der 
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Routingtabelle (iiber 1801a) an die nachfolgende Routingtabelle 
gesendet werden. Diesen Zustand verlalit die Statemachine erst 
beim Eintreffen eines ACK-Handshakes der nachfolgenden 
Routingtabelle ODER beim Eintreffen eines "disconnect"- 
Signales auf dem Bus, z.B. durch einen Timeout. Bei einem 
"disconnect" geht die Statemachine in den DISCONNECT-Zustand, 
um den Bus abzubauen (dieser Zustand ist nicht notwendig, in 
der Implementierung wird direkt nach IDLE zuruckgesprungen, 
dient aber in diesem Beispiel der besseren Ubersicht) . Bei 
Eintreffen eines ACK-Handshakes wird in den IDLE-Zustand 
zuruckgesprungen, dabei wird iiber 1909/1908 das Tor der 
vorhergehenden Routingtabelle in 1801b f reigeschaltet . 
Um die Leistung der Routingtabelle zu erhohen kann auf das 
warten auf ein ACK-Handshake wahrend des SEND-Zustandes 
verzichtet werden. Dazu miissen wahrend SEND die zu sendenden 
Zugriff sdaten an die nachfolgende Routingtabelle in 1801a 
gespeichert werden, d.h. 1801a ist ein Register; gleichzeitig 
mull wahrend SEND die Information iiber die vorhergehende 
Routingtabelle in ein zusatzliches 1801b geschrieben werden. 
Das Eintreffen des ACK-Handshakes der nachfolgenden 
Routingtabelle, bewirkt in unabhangig aufgebauter Logik das 
Abschalten von 1801a und das Umschalten von dem erste 1801b 
auf das Zweite, indem die Verschaltung des Tors der 
vorhergehenden Routingtabelle gespeichert ist. 

Die folgenden Figuren beschreiben ein Implementationsbeispiel 
nach dem "erweiterten" Routingverf ahren, der Bus sieht wie 
folgt aus: 
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Data 


Datensignale 


ACK 


Daten- und Aufbau-Handshake 


RDY 


Datenhandshake (Daten liegen an) 


DISCONNECT 


Aufforderung zum Busabbau (durch einen Timeout) 


RECONFIG 


Aufforderung zum Busabbau (durch Umkonf iguration 
der beteiligten konf igurierbaren Zellen) 


X/Y 


X/Y-Raumkoordinaten 


LUT 


Lookup-Adresse fur die Routingtabelle 


ADR-MODE 


Gibt an ob die X/Y-Raumkoodinaten oder die 
Lookup-Adresse verwendet werden soli. 1st X=0 
UND Y=0 wird automatisch die Lookup-Adresse 
verwendet . 



Figur 23 zeigt einen Knoten mit den Schaltelementen 
1,2,3,4,5,6, sowie den Bussen Bl, B2, B3, B4. 

Figur 23a) . Die Zeichnung ist zur besseren Darstellbarkeit als 
ein Ein-Leitungssystem ausgestaltet . Tatsachlich handelt es 
sich urn ein Bussystem. Dazu sind alle Figuren um die Menge der 
Busleitungen zu duplizieren. Die Schaltelemente sind im 
einfachsten Fall aus einem Transistor (2301) aufgebaut. 
Figur 23b) Um Daten zwischenspeichern zu konnen, wird das 
Schaltelement um ein Register (2302) erweitert. Uber die 
Transistoren Tl, T2, T3, T4 werden die bidirektionalen Busse 
Bn und Bm so auf das Register geschaltet, dalJ entweder der 
Ubergang 3m -> Bn oder der Ubergang Bn -> Bm gespeichert wird. 
Ober T5 wird alternativ ein bidirektionaler ungespeicherter 
Datentransfer ermoglicht. Ober die Steuersignale SI, S2, S3, 
S4 wird der Modus des Schaltelementes wie folgt eingestellt: 
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SI 


Bm -> Bn (unidirektional, gespeichert) 


S2 


Bm <-> Bn (bidirektional, nicht gespeichert) 


S3 


Bn <-> Bm (bidirektional, nicht gespeichert) 


S4 


Bn -> Bm (unidirektional, gespeichert) 



Figur 23c) Um eine bessere Signalqualitat zu erhalten, werden 
Eingangsschmittrigger und Ausgangstreiber (2303) eingesetzt. 
Die Treiber (2303) sind so ausgestaltet, daJi iiber ein 
Steuersignal pegelabhangig- entweder der Ausgangs oder der 
Eingancstreiber f reigeschaltet wird. Die Bidirektionalitat 
geht verioren, es sind ausschieftlich unidirektionale 
Schaltvorgange realisierbar : 

S4 wird der Modus des Schaltelementes wie folgt eingestellt: 



SI 


Bm 


-> 


Bn 


(unidirektional, 


gespeichert ) 


S2 


Bm 


-> 


Bn 


(unidirektional, 


nicht gespeichert) 


S3 


Bn 


-> 


Bm 


(unidirektional, 


nicht gespeichert) 


S4 


Bn 


-> 


Bm 


(unidirektional, 


gespeichert) 



Figur 23d) Die Ein- und Ausgange verlaufen auf 
unterschiedlichen Leitungen (Bmi, Bmo, Bni, Bno) zur besseren 
Implementierbarkeit in Chips. Die Treiber (2304) sind 
unidirektional ausgestaltet. Die Ansteuerung der Treiber kann 
entfallen. 
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SI 


Bmi 


-> 


Bno 


(unidirektional, 


gespeichert) 


S2 


Bmi 


-> 


Bno 


(unidirektional, 


nicht gespeichert) 


S3 


Bni 


-> 


Brno 


(unidirektional, 


nicht gespeichert) 


S4 


Bni 


-> 


Bmo 


(unidirektional, 


gespeichert) 



Figur 24 zeigt einen Knoten ahnlich dem Knoten aus Figur 23. 
Der Vorteil des Knotens liegt in seiner besseren 
Iraplementierbarkeit und Verwaltung der Register. Die Zeichnung 
ist zur besseren Darstellbarkeit als ein Ein-Leitungssystem 
ausgestaltet . Tatsachlich handelt es sich urn ein Bussystem. 
Dazu sind alle Figuren um die Menge der Busleitungen zu 
duplizieren. Die Register und Treiber (A, B, C, D) sind den 
Schaltelementen (1, 2, 3, 4, 5, 6) vorgeordnet. Die 
Schaltelemente reduzieren sich auf die in Figur 24a gezeigte 
Kreuzschaltung. Mittels der Transistoren T6, T7 werden die 
Eingange (Imi, Ini) jeweils selektiv mittels der 
Steuerleitungen S5, S6 auf die Ausgange (Imo, Ino) geschaltet. 
Die Figuren 24b-d zeigen verschiedene Ausgestaltungsarten der 
Register und Treiber (A, B, C, D) . 

In Figur 24b wird ein bidirektionaler Bus liber T8 entweder als 
Eingang zum Regsiter 2401 geschaltet, oder uber T9 aus Ausgang 
geschaltet, wobei der knoteninterne Bus Imo die Signalquelle 
darstellt. T8 und T9 werden uber die Steuerleitung S7 
angesteuert. Mittels des Transistorpaares T10/T11, das uber S8 
angesteuert wird, kann ein Register-Bypass geschaltet werden 
um den quasi-permanenten Modus zu ermoglichen. Der Ausgang des 
Registers geht auf den knoteninternen Bus Imi. Die Vernetzung 
der Imi und Imo erfolgt uber die Schaltelemente aus Figur 24a. 
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In Figur 24c wir anstatt des Transistorpaares T8/T9 eine 
Treiberstufe (2402) zur Verbesserung der Signalqualitat zum 
Bus geschaltet. 

In Figur 24d ist der externe Bus zur besseren 
Implementierbarkeit in Chips unidirektional ausgestaltet . Die 
Treiber 2403 sind unidirektional, das Steuersignal S7 
entfallt. 

Figur 25 schlagt eine mSgliche Synchronisationsschaltung fur 
Fig. 24 vor. Die Register 2401 zur Datenspeicherung sind in 

2501 dargestellt. Das Register 2502 dient der Speicherung 
eines RDY-Handshakesignales, also der Information, daft sich 
gultige Datenen auf dem Bus, bzw. in 2501 befindet. Befindet 
sich keine giiltigen Daten in 2501, ist der Ausgang Q von 2502 
logisch 0. Treffen gultige Daten ein (RDY ist aktiv und 
logisch 1), wird tiber das UND-Gatter 2503 ein 
Freischaltesignal (EN) fur die Register 2501 und 2502 
generiert, die Daten und das RDY werden mit der steigenden 
Taktflanke gespeichert. Der Eingang von 2503 fur Q (von 2502) 
ist invertierend! Treffen erneut Daten ein, ist der Ausgang 
(Q) von 2502 logisch 1. Das UND-Gatter liefert eine logische 0 
und die Register werden tiber EN nicht f reigeschaltet . Werden 
die Daten liber den Bus weitergeleitet, wird das 
Aktivierungssignal des Ausgangstreibers (OE) als Clear fur 

2502 verwendet; Q von 2502 wird logisch 0 und neue Daten 
konnen mit dem nachsten Taktzyklus gespeichert werden. Die 
Leitung Din und Dout ist fett eingezeichnet, da es sich hier 
um ein Bussystem handelt. Ebenso ist 2501 fett gezeichnet, da 
das Register der Breite des Busses entspricht. 
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Es ist moglich die Register als Latches aufzubauen und an die 
Pegei des Taktes (CLK) oder Handshakes (RDY) zu koppeln. Die 
Schaltung verhalt sich dadurch allerdings asynchron, was zu 
erheblichen Implementierungsproblemen fiihrt und dadurch einem 
nicht unerheblichem Zusatzaufwand unterliegt. 

Figur 26 zeigt die Teststrategie um f estzustellen, ob eine 
Verbindung aufgebaut werden kann, d.h. das Netz frei ist. Die 
Statusinformationen der Schaltelemente 1,2,3,4,5,6, die 
Auskunft geben ob ein Schaltelement verschaltet oder frei ist, 
werden in einer Matrix 2603 angeordnet. Dabei bilden die 90°- 
Schaireiemente 3,4,5,6 die Ecken, die 180°-Schaltelemente 1 
und 2 die Mittelstiicke und kommen doppelt vor. Um ein 
Schaltelement kollisionsf rei zu benutzen muli die gesamte Kante 
in welcher sich das Schaltelement befindet frei sein. 
Beispielsweise ist es moglich 1+2, 6+4, 3+5 zu benutzen. 
Unmoglich dagegen ist beispielsweise 6+2, 6+1, 2+5, 2+4, 2+3, 
etc. 

Es muft also sichergestellt und getestet werden, dali jede Kante 
nur einmal belegt ist. Die Daten hierzu liefert ein Register 
2602, in dem die aktuelle Verschaltung des Knoten gespeichert 
ist uber den Eingang r; sowie die Routingtabelle 2601, die die 
Daten des gewunschten neuen Busses uber den Eingang t an die 
Matrix weiterleitet . 

Die Testschaltung ist in Figur 26a dargestellt. Je eine Reihe 
(2605, 2606, 2607, 2608) wir uber ein ODER-Gatter (2609, 2610, 
2611, 2612) auf die Existenz einer Verschaltung uberpruft. 
Existiert ein verschaltetes Element in der Reihe, liefert das 
jeweilige ODER-Gatter eine logische 1. Das Ergebnis der 
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jeweiligen Reihe wird mittels jeweils eines UND-Gatters mit je 
einer sich in der Reihe befindenden, neu auf zubauenden 
Verschaltung verknupft. 1st die Reihe bereits belegt UND eine 
weitere Verschaltung in der Reihe wird angefordert, liefert 
das jeweilige UND-Gatter eine logische 1. Die Ausgange aller 
UND-Gatter werden verODERt (2613) . Das Ergebnis des Tests 
liefert sorait an 2604 eine logische 0, wenn die angeforderte 
Vernetzung gultig ist und eine logische 1, wenn eine Kollision 
vorliegt . 

Die Schaltung in Figur 26 ist lediglich in der Lage eine 
Anforderung pro Zeiteinheit zu verarbeiten. Eine zeitliche 
Optimierung ist in Figur 27 dargestellt. Uber 2701 gelangen 
die Zugrif f sanf orderungen von den Bussen an die Schaltung. Die 
Routingtabelle (2702) ist nicht aus einem iiblichen Speicher, 
sondern aus einer Mehrzahl von einzelnen Registern (2711) 
aufgebaut. Dadurch konnen uber die Multiplexer 27 03 die Daten 
samtlicher Zugrif f sanf orderungen gleichzeitig aus der 
Routingtabelle ausgelesen werden. Die Daten je einer 
Zugrif f sanf orderung werden an je eine Matrix (2704) gemali 
Figur 26 geleitet, das die Vergleichsdaten aus dem Register 
mit der aktuellen Verschaltung der Knoten (2705) erhalt. Die 
Schaltung 2706 besteht aus einem ODER-Gatter, das das 
Vorhandensein einer gultigen Anfrage an die Matrix 2704 
festsrellt. Das Ergebnis von 2704 wird uber einen Inverter mit 
dem Ausgang des ODER-Gatters verUNDet. Als Ergebnis wird bei 
einem bestehenden und gultigen Zugriff eine logische 1, 
ansonsten eine logische 0 geliefert. Jede Matrix besitzt je 
eine Schaltung 2706. Deren Ergebnisse werden auf einen Arbiter 
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2707 geschaltet, der einen der giiltigen Zugriffe auswahlt. Der 
Multiplexer 2708 wird so geschaltet, dafi die Daten des 
giiltigen Zugriffes auf den Mischer 2709 gelangen, der den 
giiltigen neuen Zugriff mit der bestehenden Verbindung 
verknupft und an das Register 2705 zur Speicherung 
weiterleitet . 

Diese Schaltung ist in der Lage aus einem Menge von 4 
Zugriff en genau einen Giiltigen auszuwahlen. Durch Anderung der 
Anzahl der Multiplexer (2703), Matrizen (2704), der Arbiter- 
und Multiplexerbreite (2707, 2708) sowie der dazugehdrenden 
Logiken, kann ein gultiger Zugriff aus einer beliebig 
einsteilbaren Menge von Anfragen bearbeitet werden. 

Oftmals ist es erforderlich mehr als einen giiltigen Zugriff 
aus einer Menge von Zugriff en auszuwahlen. Dazu dienen die 
Leitungen 2801, 2805, 2802 und 2810, die zu der 
Zusatzschaltung Figur 28 ftihren und eine gleichzeitige Auswahl 
von 2 Zugriffen ermdglichen. Wird 2810 verdrahtet, entfallt 
die Leitung 2710. Nach dem im Folgenden vorgestellten Prinzip 
kann durch Kaskadierung eine beliebige Menge von Zugriffen 
gleichzeitig ausgewahlt werden. 

Uber 2801 gelangt die Information, welcher Zugriff als 
"giiltig" ausgewahlt wurde, an den Dekoder 2803. Die 
Information wird so auskodiert, dali uber die drei Multiplexer 
2804 nur die Zugriff sdaten der nicht ausgewahlten Zugriff an 
die Matrizen geleitet werden. Durch den Wegfall des bereits 
ausgewahlten Zugriffes verringert sich die Zahl der Matrizen 
um eins. 
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Der Dekoder arbeitet wie in der Tabelle angegeben: 



Dekoder 
(2802) 


MUX1 


MUX2 


MUX 3 


a 


b 


c 


d 


b 


a 


c 


d 


c 


a 


b 


d 


d 


a 


b 


c 



Die Tabelle gibt in der Spalte "Dekoder" den uber 2802 
selektierten "gultige" Bus an. In den Spalten MUX1-MUX3 wird 
angegeben, welchen Bus der jeweilige Multiplexer, abhangig von 
dem Wert 2802, selektiert. 

Die Matrizen (2811), die Logik (2806) und der Arbiter (2807) 
arbeiten wie aus Figur 27 bekannt. Uber den Multiplexer 2808 
werden die Daten des vom Arbiter ausgewahlten Zugriffes an dem 
Mischer 2809 geleitet. Der fugt ahnlich dem Mischer 2709 den 
Ausgangsdaten von 2709 die Daten des von der Logik von Figur 
28 ausgewahlten Zugriffes zu und leitet die generierten 
Zugriffsdaten uber 2810 an das Register 2705. Die 
Eingangsdaten des Multiplexers 2808 miissen aufgrund der 
Verschaltung in den Multiplexer 2804 von deren Ausgangen 
abgegriffen werden. 

Die Schaltung gemafi Fig. 28 ist in die Tiefe nach dem 
beschriebenen Prinzip weiter kaskadierbar, wobei sich die Zahl 
der Matrizen weiter um jeweils eins pro Kaskade verringert. 

Figur 29 beschreibt ein Register gemali 2602 bzw. 2705. Die 
Ausgange der Mischer 2709 bzw. 2809 werden uber 2901 als 
Eingangsdaten an das Register gefuhrt. Je eine Registerbank 
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2902a/b verwaltet einen der Busse (Bl,B2,..Bm) des Knotens. Im 
Teil a einer Bank ist die Ansteuerung des Knotens gespeichert. 
In Teil b ist das Timeout der Busverbindung definiert. Teil b 
besteht aus einem ladbaren zahler, dessen enable und reload 
uber den Multiplexer 2903, einstellbar durch Teil a, gewahlt 
wird. 



Timeout-Prinzip 


Wirkung 


BUS-ACK 


Die Datentransfers werden gezahlt. 
(Bus in use / Paketgrofie) 


! BUS-ACK 
(invertiert) 


Die Takte ohne Datentransf er werden 
gezahlt. (Bus NOT not use / Timeout) 


en 


Jeder Takt wird gezahlt / Takt-Zyklen 




Kein Timeout / permanent 



Die Signale reload und enable des Zahlers werden bie folgt 
generiert : 



Timeout-Prinzip 


reload (rid) 


enable (en) 


BUS-ACK 


nie 


bei Datentransfer 


! BUS-ACK 
(invertiert) 


bei Datentransf er 


ohne Datentransfer 


en 


nie 


standig 




nie 


nie 



Dabei ist das fur einen Reload, also das Neuladen des Zahlers, 
benotigte Register, das den ursprunglich gesetzten Zahlerstand 
enthalt in 2902b enthalten. 2904 testet auf den Zahlerstand 0 
um den Timeout festzustellen. 2904 ist in der Figur nur des 
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Verstandnis halber aufgezeigt; in der Implementierung wird das 
Ubertragssignal (Ripple-Carry) des Zahlers verwendet. Der 
Obertrag loscht den Inhalt von 2902a, welches danach die 
Zustandsinformation "Bus-frei" weitergibt und somit den Bus 
abreiiit. Aus dem Obertrag wird als Signal BUS-DISCONNECT auf 
den Bus geschaltet und zum AbriB der restlichen Bussegment 
verwendet. BUS-RECONF wird gemali DE 197 04 728.9 mit den Daten 
mitgefiihrt und bewirkt bei Auftreten ebenfalls den Abrili des 
Busses. Uber das ODER-Gatter 2905 werden beide Signale 2902 
zugefuhrt und bewirken das Loschen des Registers und ZShlers . 
Der Timeout wird deaktiviert, indem gemafi den vorher 
aufgefuhrten Tabellen das enable-Signal deaktiviert ist und 
der Zahler mit einem Wert grofier null geladen wird. 
Die Daten in dem Register sind busorientiert, nicht 
schaltelementorientiert . Diese Daten gelangen uber 2906 an die 
Mischer 2709 und 2809. Jedes Steuersignal kommt m-fach (Anzahl 
der Busse) vor und wird in der Notation Si, m bezeichnet, wobei 
m fur den Bus und i fur die Nummer des Schaltelements steht. 
Bevor die Daten an eine Matrix gemali Figur 26 oder an einen 
Knoten gemali den Figuren 23/24 gefuhrt werden mussen diese in 
der Art abgebildet werden, dafi lediglich eine Folge T ± 
existiert. Die Abbildungsvorschrif t lautet dabei Ti = (S i( i u 
Si, 2 u Si, 3 u ... yj Si, m ) , mit anderen Worten alle S i(1 bis S i(m 
werden verODERt. 2907 ubernimmt diese Funktion und fuhrt T 
uber 2908 den Matrizen und Schaltelementen zu. 

Figur 30 zeigt ein Beispiel fur zwei Busverbindungen. 

Konf igurierbaren Elementen oder Gruppen von konf igurierbaren 
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Elementen (3001) ist ein Knoten 3002 zugeordnet. Der Kr.oten 
3003 ubertragt Daten zum Knoten 3004. Der Verbindungsauf bau 
ist statisch. Der Knoten 3005 ubertragt die Daten dynamisch an 
den Zielknoten 3008. Dabei sind die Segmente 3006 und 3007 
belegt, sodaii sich die Laufrichtung jeweils andert. Die X/Y- 
Raumkoordinaten sind in den jeweilig durchlaufenen Knoten 
angegeben. Dabei werden die Koordinaten je nach Laufrichtung 
gleichbehalten, um eins erhoht oder verringert. Anhand des 
Zahlenwertes der Koordinaten kann die Laufrichtung und das 
Ziel ausgemacht werden. Dabei wird aus der Position (A, B, C, 
D) des eingehenden Busses am Knoten und dera Vorzeichen der 
(X/Y)- Bewegung die Abweichung der Bewegungsrichtung 
berechnet. Dabei werden Himmelsrichtungen zur Bezeichnung 
verwendet, wobei y die Nord-Sud Achse und x die Ost-Wes- Achse 
bildet: 



Laufrichtung 


Bewegung in 
Himmelsrichtung 


y = 0 


x > 0 => 0 
x < 0 => W 


y > 0 


N 


y < 0 


S 


x = 0 


y > 0 => N 
y < 0 => S 


x > 0 


0 


x < 0 


W 
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Anhand der Lauf richtung und der Himmelrichtung des eingehenden 
Busses kann berechnet werden, welches der Schaltelemente 
(1,2,3,4,5,6) angesprochen wird. Beide oben genannten 
Berechnungen sind trivial, so dali die notwendige 
Berechnungseinheit (XY2ADR) beispielsweise durch Lookup- 
Tabellen ausgestaltet werden kann. Daher wird auf die 
Berechnung nicht weiters eingegangen, sondern auf die oben 
gezeigte Tabelle verwiesen. 

Die Adressierung in diesem Beispiel ist relativ. 

Figur 31 zeigt dasselbe Beispiel mit absoluten Koordinaten. Im 
Gegensatz zu Figur 30 werden die Koordinaten in den Knoten 
nicht berechnet, sondern mit den Koordinaten der Knoten gemafi 
dem ubergeordneten Koordinatensystem 3101 verglichen. Anhand 
der Vergleiche, grolier (>) , kleiner (<) und gleich ( = ) wird 
der Verbindungsaufbau gesteuert. Sind beide Koodinaten (X und 
Y) gleich den Koordinaten des Knotens, ist das Ziel erreicht, 
ist eine Koordinate gleich der Koordinate des Knotens, ist die 
Zielachse der Koordinate erreicht. 

Die in den Figuren 30 und 31 aufgefuhrten Beispiele lassen 
keine Abweichung von der optimalen Richtung zu. Ware 
beispielsweise das Segment 3009 in Figur 30 belegt, konnten 
die Daten nicht weiter transferiert werden. Es ist moglich im 
Besetzt-Fall eine Abweichung von der vorgegebenen Richtung 
zuzulassen. Dann konnte die Verbindung iiber 3010 aufgebaut 
werden. Allerdings mull der Raum fUr eine mogliche Abweichung 
begrenzt werden, urn keine unsinnigen Routingversuche zu 
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erhalten. Eine sinnvolle Schranke fur Abweichungen von der 
vorgegebenen Richtung liegt bei +/-1 bis +1-2. 

Figur 32a und 32b zeigen die notwendige Peripherie urn einen 
Knoten 3201, um die Raumkoordinaten auszuwerten, bzw. zu 
modif izieren. 

Figur 32a modifiziert relative Koordinaten entsprechend ihrer 
Laufrichtung. In positiver Richtung wird subtrahiert (3203), 
in negativer Richtung addiert (3202). Die Vergleicher (3204) 
stellen priifen, ob eine Koordiante 0 erreicht hat. 
Figur 32b vergleicht absolute Koordinaten mit den Koordinaten 
des Knotens, mittels der Vergleicher 3205. 
Um eine Abweichung von der vorgegebenen Richtung zu 
ermoglichen, werden die Vergleicher 3205 und 3204 so 
erweitert, dali sie die Information, ob sich eine Koordinate im 
Abweichungbereich befindet uberpriifen und weitergeben 
(-Abweichung<Koordinate<Abweichung) . Anhand dieser Information 
kann die Berechnungseinheit (XY2ADR) bei einer Kollision der 
vorgegebenen Richtung, die Bewegungsrichtung innerhalb der 
Grenzen der zulassigen Abweichung modifizieren und eine 
Abweichung zulassen oder verhindern. Auch diese Berechnung ist 
trivial und kann ggf. durch Erweiterung der Lookup-Tabellen 
durchgeftihrt werden, in der nachf olgenden Tabelle ist die 
maximal zulassige Abweichung durch A angegeben: 
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Lauf richtung 


Bewecruncr in 
Hiirane Is richtung 


y-A = 0 


x+A > 0 0 
x-A < 0 => W 


y+A > 0 


N 


y-A < 0 


S 


x-A = 0 


y+A > 0 => N 
y-A < 0 => S 


x+A > 0 


0 


x-A < 0 


W 



Die Umgebung von x und y wird dabei unscharf, d.h. es ist 
moglich, daft Bewegungen in entgegengesetzte Himmelsrichtungen 
zulassig werden, da gleichzeitig k-A<0 UND k+A>0 gel ten kann. 
Dies kann wenn gewunscht eingegengt werden, indem keine 
Lauf richtung entgegen des Vorzeichens von k zugelassen wird. 
Ist k = 0 sind alle Lauf richtungen zugelassen. 

Figur 33 zeigt das Verhalten eines segmentierten Busses. Der 
Aufbau der Zeichnung entspricht dem bereits bekannten. Ein 
Senderknoten Sa sendet Daten an den Empf anger konten Ea, ein 
weiterer Senderknoten Sb sendet an Eb und ein Letzter Sc an 
Ec, der auch der Empf angerknoten Eb ist. Dabei treten an den 
Segmenten 3301 und 3302 Kollisionen auf. Zur optimalen 
Ausnutzung des Busses (abgesehen davon, dafi prinzipiell eine 
andere Wegfuhrung moglich ware) werden alle Busse quasi- 
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permanent aufgebaut; mit Ausnahme der Segmente 3301 und 3302. 
Diese Segmente arbeiten in dem Modus "Registered" und 
arbitrieren gemafi dem eingestellten Timeout je einen der 
anstehenden Busse. Ober den jeweiligen Timeout kann die 
Prioritat der einzelnen Busse festgelegt werden. Ein 
relevanter Bus erhalt grolie "Timout-Rechte", also lange 
Zyklen, wahrend einem irrelevanten Bus kurze Zyklen zur 
VerfUgung stehen. 

Die bisherigen Beschreibungen der Knoten in den Figuren 23-27 
zeigen der Vereinf achung halber nur die Vernetzung in die vier 
Himmelsrichtungen. Tatsachlich miissen in einem Knoten jedoch 
zusatzlich jeweils eine konf igurierbare Zelle oder eine Gruppe 
von konfigurierbaren Zellen auf geschaltet werden. Die hierfur 
notwendigen Erweiterungen sind in Figur 34 dargestellt. Die 
Kennzeichnungen der Knoten entsprechen in Figur 34a der Figur 
23 und in Figur 34b der Figur 24; der AnschlufJ der 
konfigurierbaren Elemente ist mit Z gekennzeichnet . Die Matrix 
2603 ist gemali Figur 34c zu 3401 zu andern. Die Anderung der 
Verschaltung erfolgt entsprechend Fig. 26. 

Die vorgestellten Beispiele sind der Verstandlichkeit halber 
auf 2-dimensionale Systeme ausgelegt. Auf Grundlage der 
vorgestellten Verfahren sind entsprechend komplexe beliebig 
mehrdimensionale Systeme baubar. 
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Begrif f sdef inition 

Addr ess -Lookup Die Adresse wird nicht berechnet, sondern 

durch "nachsehen" in einem Speicher generiert. 

ALU Arithmetisch logische Einheit. Grundeinheit zum 

Verarbeiten von Daten. Die Einheit kann arithmetische 
Operationen wie Addition, Subtraktion, unter Umstanden auch 
Multiplikation, Division, Reihenentwicklungen usw. durch\- 
ftihren. Dabei kann die Einheit als ganzzahlige (integer) 
Einheit oder als Flieftkomma- (floating-point) -Einheit gestaltet 
sein. Ebenfalls kann die Einheit logische Operationen, wie 
UND, ODER, sowie Vergleiche durchfuhren. 

Aufbauphase Zyklus wahrend dessen ein Bussegment aufgebaut 
wird. 

Arbiter Einheit um Rechte zwischen Signalen zu verteilen. 

bidirektional Datenubertragung in beide Richtungen 

(Quelle/Ziell <-> Quelle/Ziel2 ) 

Broadcast Senden von Daten einer PAE an mehrere oder alle 

Datenempf anger . 

Busanforderung Die Anforderung eine Busverbindung zum 

Datentransfer aufzubauen. (Auch Verbindungsanforderung) 
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Bussegment Abschnitt eines Bussystems zwischen zwei 

Knoten 

Buszustande Art und Weise wie ein Bus arbeitet. Es wird 
zwischen zwei Hauptzustanden unterschieden: 
Quasi -permanent: Der Bus verhalt sich wie eine durchgehende 
Leitung. Der Bus ist nur von einem Datenpaket verwendbar (bis 
zu seinem Abriss) . 

Registered: Zwischen jedem Segment ist ein Register 
eingeschleif t, das die Daten um einen Taktzyklus verzogert. 
Bei jedem Taktzyklus (abhangig von Timeout) kann ein anderes 
Datenpaket arbitriert werden. 

Eine Mischung der beiden Zustande ergibt den Zustand 
Segmentiert, der beide Vorteile miteinander verbindet. 

Datenempf anger Die Einheit(en), die Ergebnisse der PAE 
weiterverarbeitet/-arbeiten} 

Oatensender Die Einheit (en) , die Daten fur die PAE als 

Operancien zur Verfugung stellt/stellen } 

Datentyp Art der Daten: Zeichen, Zahlen, 

Flielikommazahlen, Signale (boolean), etc. 

Dezimaldekoder Wandelt ein binares Signal in ein 

Dezimales um. 
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DFP DatenfluJiprozessor nach Patent/Of fenlegung DE 44 16 

881 

DISCONNECT Von Timeout-Zahlern/Generatoren generiertes 
Signal zum Abriss eines Busses. Wird an alle Knoten eines 
Busses gefuhrt. 

DPGA Dynamisch konf igurierbare FPGAs . Stand der Technik 

EALU Erweiterte arithmetisch logische Einheit. ALU, die 

urn Sonderfunktionen, die zum Betrieb einer 

Datenverarbeitungseinrichtung gemali DE 441 16 881 Al bendtigt 
werden oder sinnvoll sind erweitert wurde. Dies sind ins 
besondere Zahler.} 

Elemente Sammelbegrif f fur alle Arten von in sich 
abgeschlossenen Einheiten, welche als Stuck in einem 
elektronischen Baustein zum Einsatz kommen kdnnen. Elemente 
sind also: 

- Konf igurierbare Zellen aller Art 

- Cluster 

- RAM-Blocke 

- Logik 

- Rechenwerke 

- Register 

- Multiplexer 

- I/O Pins eines Chips 
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Enable Freischalten eines Registers Oder Zahlers. 

FPGA Programmierbarer Logikbaustein. Stand der Technik. 

Gatter Gruppe von Transistoren, die eine logische 
Grundfunktion durchfuhren. Grundf unktionen sind z.B. NAND, 
NOR, Transmission-Gates. 

Geschwindigkeitsoptinxiert Ein Bussystem, das meist quasi- 
permanent aufgebaut ist, eine hohe Prioritat besitzt und nicht 
von anderen Zugriffen beeinfluftt wird. 

H-Pegel Logisch 1 Pegel, abhangig von der verwendeten 
Technologie 

Knoten Element das mehrere Bussegmente miteinander 
verbindet und den Verbindungsaufbau aktiv steuert, wahrend des 
Datentransfers jedoch passiv ist. 

konf igurierbares Element Ein konf igurierbares Element stellt 
eine Einheit eines Logik-Bausteines dar, welche durch ein 
Konf igurationswort fur eine spezielle Funktion eingestellt 
werden kann. Konf igurierbare Elemente sind somit, alle Arten 
von RAM-Zellen, Multiplexer, Arithmetische logische Einheiten, 
Register und alle Arten von interner und externer 
Vernetzungsbeschreibung etc. 

konfigurierbare Zelle Siehe Logikzellen 
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Konfigurieren Einstellen der Funktion und Vernetzung einer 
logischen Einheit, einer (FPGA)-Zelle Oder einer PAE (vgl. 
umkonf igurieren) . 

Ladelogik Einheit zum Konfigurieren und Umkonf igurieren 

der PAE. Ausgestaltet durch einen speziell an seine Aufgabe 
angepaliten Mikrokontroller . 

Latch Speicherelement, das ein Signal fur gewohnlich 

wahrend des H-Pegels transparent weiterleitet und wahrend des 
L-Pegels speichert. In PAEs werden teilweise Latches 
gebraucht, bei denen die Funktion der Pegel genau umgekehrt 
ist. Hierbei wird vor den Takt eines ublichen Latch ein 
Inverter geschaltet. 

Logikzellen Bei DFPs, FPGAs , DPGAs verwendete 

konfigurierbare Zellen, die einfache logische oder 
arithmetische Aufgaben gemafi ihrer Konf iguration erfullen. 

LookUp-Tabelle (LUT) Tabelle, die einen Wert als Adresse 

erhalt und ein Ergebnis zurucklief ert . Beispielsweise wird 
eine Zahl als Adresse angegeben und deren sinus wird 
zuriickgegeben. 

L-Pegel Logisch 0 Pegel, abhangig von der verwendeten 
Technologie 
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M-PLUREG Register in dem die Vernetzung der PAE gesetzt 

wird. Das Register wird von der PLU beschrieben. 

Maske Eine Bitkombination, die angibt, welche Signale 
einer Quelle weitergeleitet werden und welche Signale 
unterbrochen (ausmaskiert) werden. 

Mischer Einheit zum Verschalten mehrerer Signale nach einer 
bestimmten Abbildungsvorschrif t . 

a) Fur gewohnlich findet eine logische Operation (UND/ODER) 
statt, cder 

b) die Signale werden zu einem Bus zusammengefalit, wobei evtl. 

c) mehrere Signalquellen uber mehrere Multiplexer selektiv 
zusammengefaJit werden. 

Open-Kollektor Schaltungstechnik, bei der der Kollektor eines 
Transistors an einem, uber einen Pullup auf den H-Pegel 
gezogenen, Bussignal liegt. Der Emitter der Transistors liegt 
auf Masse. Schaltet der Transistor, so wird das Bussignal auf 
den L-Pegel gezogen. Vorteil des Verfahrens ist, daB eine 
Mehrzahl solcher Transistoren den Bus ohne elektrische 
Kollision steuern konnen. Dabei sind die Signale ODER- 
verkiipft, es entsteht das sog. wired-OR. 

PAE Processing Array Element: EALU mit O-REG, R-REG, 

R20-MUX, F-PLUREG, M-PLUREG, BM-, SM-, Sync-, StateBack- und 
Power-UNIT. 
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Partnerknoten Knoten mit dem ein bestimmter Knoten uber 

ein Bussegment Kontakt hat oder aufbauen will. 

PLU Einheit zum Konf igurieren und Umkonf igurieren der 

PAE. Ausgestaltet durch einen speziell an seine Aufgabe 
angepaiiten Mikrokontroller . 

Prioritatsart Art und Weise, wie eine Prioritatskennung 

ausgewertet wird. 

Prioritatsdekoder Das Signal mit der hochsten Prioritat 

wird weitergegeben oder f reigeschaltet . 

Prioritatskennung Angabe der Prioritatsebene (hoch bis 

nieder) einer Busverbindung . 

Priority-Logik Das Signal mit der hSchsten Prioritat wird 

weitergegeben oder f reigeschaltet . 

PullDown Widerstand, der eine Busleitung auf einen L-?egel 
zieht. 

PullUp Widerstand, der eine Busleitung auf einen H-Pegel 
zieht . 
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Quellenoptimiert Ein Bussystem, das meist registered und 
mit niederen Prioritaten aufgebaut ist, urn moglichst vielen 
Datensendern (Quellen) den Zugriff auf den Bus zu ermoglichen. 

Raumkoordinaten Angabe von Punkten mittels eines 
mehrdimensionalen Koordinatensystemes . Es konnen absolute 
Koordinaten (exakte Adresse eines Punktes) oder relative 
Koordinaten (relative Entfernung von einem Ausgangspunkt) 
verwendet werden. Eine Bewegung in positiver Richtung erhoht 
den Zahlenwert einer Koordiante, eine Bewegung in negativer 
Richtung verringert den Zahlenwert einer Koordinate. 

RECONFIG Von konf igurierbaren Elementen generiertes 

Signal das anzeigt, dali die Eleraente umkonf iguriert werden 
konnen und ihre Aktivitat beendet haben. Wird zum Abriss aller 
beteiligten Busses verwendet und an alle Knoten eines Busses 
gefuhrt . 

Registerbank Zusammenfassung mehrerer in Grolier und 

Funtkion unterschiedlicher Register zu einer Gruppe. 

Register-Bypass Leitung zum Umgehen eines Registers, 
dadurch wird der Synchronisationsef f ekt des Registers 
ausgeschaltet . 

RELOAD Neuladen eines Zahlers mit seinem ursprunglich 
gesetzten Wert. 
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Routingtabelle Tabelle innerhalb eines Knotens, die 

Inf ormationen uber aufzubauende Verbindungen enthalt. 

Round-Robin -Arbiter Arbiter, der der Reihe nach ein 

Signal nach dera anderen f reischaltet . Das aktuell 
freigeschaltete Signal bekommt die niederste Prioritat und 
wird als Letztes in der Kette dann wieder f reigeschaltet . Der 
Arbiter arbeitet im Kreis. 

Sammelschiene Bus auf dem mehrere Bussegmente zusammengef iihrt 
werden . 

Schmitt-Trigger Fensterkomparator, der uber eine Hysterese 
einem Signal genau einen von zwei Werten zuweist und dadurch 
die Signalqualitat verbessert. 

Switching-Tabelle Eine Switching-Tabelle ist ein Ring- 

Speicher, welcher durch eine Steuerung angesprochen wird. Die 
Eintrage einer Switching-Tabelle konnen beliebige 
Konf igurationsworter aufnehmen. Die Steuerung kann Befehle 
durchfuhren. Die Switching-Tabelle reagiert auf Triggersignale 
und konfiguriert konf igurierbare Elemente anhand eines 
Eintrages in einem Ringspeicher urn. 

Timeout-Generator Einheit zum Generieren eines Timeouts nach 
unterschiedlichen Kriterien, wie 

- Taktzyklen ohne erfolgten Verbindungsaufbau 

- ubertragene Datenpakete 
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- Taktzyklen 

- Taktzyklen ohne Obertragung 

Timeout Nach Ablauf einer bestirranten Zeit geschieht 

etwas (ein Vorgang wird begonnen oder unterbrochen) . 

Timeout- Zahler siehe Timeout-Generator 

Tor Schalter, der ein Signal weiterleitet oder sperrt. 

Einfacher Vergleich: Relais 

unidirektional Datenubertragung in eine Richtungen 

(Quelle -> Ziel) 

Umkonf igurieren Neues Konf igurieren von einer 

beliebigen Menge von PAEs wahrend eine beliebige Restmenge von 
PAEs ihre eigenen Funktionen fortsetzen (vgl. konf igurieren) . 

Verbindungsanforderung Die Anforderung eine 

Busverbindung zum Datentransf er aufzubauen. (Auch 
Busanforderung) 

Zellen Synonym fur konf igurierbare Elemente 

Zielachse Die X/Y-Achse an der X = 0 ist oder X = Achse, 

bzw. Y = 0 oder Y = Achse ist die Zielachse von X bzw. Y. 
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Zustandsmaschine Logik, die diversen Zustande annehmen 

kann. Die Ubergange zwischen den Zustanden sind von 
verschiedenen Eingangsparametern abhangig. Diese Maschinen 
werden zur Steuerung komplexer Funktionen eingesetzt und 
entsprechen dem Stand der Technik 
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Naraenskonvention 



Baugruppe -UNIT 

Betriebsart -MODE 

Multiplexer -MUX 

Negiertes Signal not- 

Register far PLU sichtbar -PLUREG 

Register intern -REG 

Schieberegisters -sft 
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Patentanspriiche 

1. Bussystem fur DFPs gemaft DE 44 16 881 Al, sowie Bausteine 
mit zwei- oder mehrdimensionaler programmierbarer Zellstruktur 
(der Gattungen FPGA, DPGA, o.dgl.), dadurch gekennzeichnet, 
daJi 

a) das Bussystem aus einer Vielzahl voneinander 
elektrisch unabhangiger Bussegmente besteht, die uber 
Knoten getrennt sind, 

b) die Knoten Bussegmente aktiv zusammenfugen oder 
trennen, wobei 

bl) entweder zum Zusammenfugen mehrere Bussgmente 
uber Tore auf eine, sich innerhalb des Knoten 
befindende Sammelschiene zusammengeschaltet 
werden, oder 

b2) die Zusammenfugung direkt uber Schaltelemente, 
Treiber und/oder Register erfolgt, 

c) jeder Knoten eine Routingtabelle besitzt, in der die 

Inf ormationen uber den Aufbau der Verbindungen 
gespeichert sind, 

d) jeder Knoten eine Oberwachungseinheit besitzt, die 

selbstandig pruft ob eine Verbindung aufgebaut werden 
kann oder nicht. 

2. Bussystem nach Patentanspruch 1, dadurch gekennzeichnet, 
daJi 

eine Busverbindung schrittweise aufgebaut wird, wobei der 
Datensender zunachst nur die Verbindung zu dem mit ihm 
verbundenen Knoten herstellt, der Knoten dann uber seine 
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Routingtabelle feststellt, welcher ihm benachbarte Knoten fur 
die Verbindung benotigt wird und zu diesem iiber das 
verbindende Bussegment Verbindung aufnimmt, sofern dieses 
nicht bereits von einer anderen Verbindung belegt ist; ist 
dies der Fall, so wird der Aufbau der Busverbindung 
abgebrochen oder ausgesetzt; ist dies nicht der Fall, so setzt 
der angesprochene Knoten den Aufbau der Busverbindung fort. 

3. Bussystem nach Patentansspruch 1, dadurch gekennzeichnet, 
dali 

ein Bussegment zur Obertragung eines Datenpaketes aufgebaut 
wird, wobei der Datensender zunachst die Verbindung zu dem mit 
ihm verbundenen Knoten herstellt, der Knoten dann uber seine 
Routingtabelle feststellt, welcher ihm benachbarte Knoten fur 
die Verbindung benotigt wird und die Daten uber das 
entspechende Bussegment weiterleitet, sofern dieses nicht 
bereits von einer anderen Verbindung belegt ist; ist dies der 
Fall, so wird der Aufbau der Busverbindung ausgesetzt; ist 
dies nicht der Fall, werden die Daten in dem Knoten geloscht 
und von dem benachbarten Knoten weiterverarbeitet . 

4. Bussystem nach Patentanspruch 1-3, dadurch gekennzeichnet, 
daJi 

die Adressen der Daten oder der Verbindung in der Lookup- 
Tabelle eines Knotens auf die Adressen des nachsten Knotens 
iibersetzt werden. 

5. Bussystem nach Patentanspruch 1-3, dadurch gekennzeichnet, 
dail 
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die Adressen der Daten oder der Verbindung in einer 
Berechnungseinheit eines Knotens so verrechnet werden, daft 
entweder die Adresse des nachsten Knotens errechnet wird oder 
uber die Lookup-Tabelle die Adressen des nachsten Knotens 
generiert werden. 

6. Bussystem nach Patentanspruch 1 bis 5, dadurch 
gekennzeichnet, daft 

bei einem f ehlgeschlagenen Verbindungsaufbau der Aufbau zu 
einem spateren Zeitpunkt erneut versucht wird. 

7. Bussystem nach Patentanspruch 1 bis 6, dadurch 
gekennzeichnet, daft 

nach einem erfolgten Verbindungsaufbau die Knoten passiv sind 
und der Datentransf er ausschlieftlich von Datensender und 
Datenempf anger gesteuert werden. 

8. Bussystem nach Patentanspruch 1 bis 6, dadurch 
gekennzeichnet, daft 

ein Knoten aktiv die Daten zu dem nachsten Knoten ubertragt 
und die Synchronisation ubernimmt. 

9. Bussystem nach Patentanspruch 1 bis 8, dadurch 
gekennzeichnet, daft 

weder Datensender noch Datenempfanger, weder wahrend des 
Verbindungsaufbaus noch des Betriebs, Kenntniss uber das 
Bussystem haben und keinerlei aktiven Eingriff auf die Knoten 
nehmen . 
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10. Bussystem nach Patentanspruch 1 bis 9, dadurch 
gekennzeichnet, dali 

die Knoten und deren Routingtabellen von einer Ladelogik 
konf iguriert und umkonf iguriert werden. 

11. Bussystem nach Patentanspruch 1 bis 10, dadurch 
gekennzeichnet, dali 

iiber die Routingtabellen Ruckmeldungen an die Ladelogik 
gesendet werden konnen. 

12. Bussystem nach Patentanspruch 1 bis 11, dadurch 
gekennzeichnet, dali 

ein Knoten Daten an mehrere andere Knoten gleichzeitig 
versenden kann (Broadcasting), wobei die 

Synchronisationssignale der empfangenden Knoten einstellbar 
boolsche verknupft und einstellbar maskiert an den sendenden 
Knoten zuriickgegeben werden. 

14. Verfahren zur Ubertragung von Daten in DFPs gemali DE 44 16 
881 Al, sowie Bausteine mit zwei- oder mehrdimensionaler 
programmierbarer Zellstruktur (der Gattungen FPGA, DPGA, 
o.dgl.), dadurch gekennzeichnet, dali 

die Ubertragung der Daten segmentweise auf einem 
mehrdimensionalen Bussystemen erfolgt, wobei die Segmente 
beliebig zusammengeschaltet werden konnen und die 
Datenubertragung synchronisiert erfolgt. 

15. Verfahren nach Anspruch 14 dadurch gekennzeichet, dali 
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die Segmente der Busse fest zu einem durchgangigen 
unverzogerten Bussystem zusammengeschaltet werden. 

16. Verfahren nach Anspruch 14 dadurch gekennzeichet , daft 
die Segmente der Busse durch Register zeitverzogert und 
arbitriert verschaltet werden. 

17. Verfahren nach Anspruch 14 bis 16 dadurch gekennzeichet, 
daB 

die beide Verschaltungsverf ahren gemali den Abspruchen 15 und 
16 bei einer Verbindung vorkonunen . 

18. Verfahren nach Anspruch 14 bis 17 dadurch gekennzeichet, 
daJi 

der Aufbau eines Busses durch Lookup-Tabellen gesteuert wird, 
in denen die Verbindungsdaten abgelegt sind, wobei in jeder 
Lookup-Tabelle der Eintrag der nachfolgenden Tabelle 
referenziert ist. 

19. Verfahren nach Anspruch 14 bis 17 dadurch gekennzeichet, 
daft 

der Aufbau des eines Busses durch die Angabe einer eindeutigen 
berechenbaren relativen oder absoluten Adresse des Zieles 
erf olgt . 

20. Verfahren nach Anspruch 14 bis 17 und 19 dadurch 
gekennzeichet, daft 

eine vorliegende Aufbaurichtung nur gewechselt wird, wenn die 
Zielachse erreicht ist. 
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21. Verfahren nach Anspruch 14 bis 17 und 19 dadurch 
gekennzeichet, daI3 

eine vorliegende Aufbaurichtung gewechselt wird, sobald eine 
Blockade in der vorliegenden Aufbaurichtung auftritt. 

22. Verfahren nach Anspruch 14 bis 17 und 19 dadurch 
gekennzeichet, daJi 

kein Aufbau entgegen der Aufbaurichtung und uber die Zielachse 
hinaus erfolgt. 

23. Verfahren nach Anspruch 14 bis 17 und 19 dadurch 
gekennzeichet, daB 

ein Aufbau entgegen der Aufbaurichtung und uber die Zielachse 
hinaus erfolgen kann, sofern sich die Abweichung innerhalb 
eines fest vorgegebenen Raumes bewegt. 

24. Verfahren nach Anspruch 14 bis 23 dadurch gekennzeichet, 
dali 

die beide Aufbauverf ahren gemali den Abspruchen 18 und 19 bei 
einer Verbindung vorkommen. 

25. Verfahren nach Anspruch 14 bis 24 dadurch gekennzeichet, 
dali 

beim Auftreten mehrere Anf orderungen an einem Knoten die 
Anforderungen arbitriert werden. 

26. Verfahren nach Anspruch 14 bis 25 dadurch gekennzeichet, 
dali 
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beim Auftreten mehrere Anf orderungen eine Mehrzahl von 
Anforderungen zeitgleich behandelt werden. 

27. Verfahren nach Anspruch 14 bis 26 dadurch gekennzeichet, 
dali 

Daten uber ein Bussegment an einen nachsten Knoten gesendet 
werden und der nachste Knoten die Daten bestatigt. 

28 . •Verfahren nach Anspruch 14 bis 26 dadurch gekennzeichet, 
dali 

Daten iiber ein Bussegment an mehrere nachsten Knoten gesendet 
werden und die nachste Knoten die Daten bestatigen, wobei die 
Bestatigungssignale beliebig in boolscher Algebra verknupft 
werden. 

29. Verfahren nach Anspruch 14 bis 26 und 28 dadurch 
gekennzeichet, dali 

Daten uber ein Bussegment an mehrere nachsten Knoten gesendet 
werden und die nachste Knoten die Daten bestatigen, eine Maske 
zum ausmaskieren einzelner Bestatigungssignale existiert. 

30. Verfahren nach Anspruch 14 bis 28 dadurch gekennzeichet, 
dali 

die beide Obertragungsverf ahren gemaJi den Abspriichen 27 und 28 
bei einer Verbindung vorkommen. 

31. Verfahren nach Anspruch 14 bis 30 dadurch gekennzeichet, 
dali 
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ein bestehender Bus aufgrund eines Abrifi-Signales aufgelost 
wird, das an alle beteiligten Knoten geleitet wird. 

32. Verfahren nach Anspruch 14 bis 31 dadurch gekennzeichet , 
daft 

ein Abrift-Sigtnal aufgrund einer Zeitiiberschreitung von einem 
Oder mehreren Knoten generiert wird und an alle beteiligten 
Knoten geleitet wird. 

33. Verfahren nach Anspruch 14 bis 32 dadurch gekennzeichet, 
daft 

eine Zeitiiberschreitung aufgrund eines Zeitraums erfolgt, 
indent keine Daten ubertragen wurden. 

34. Verfahren nach Anspruch 14 bis 32 dadurch gekennzeichet, 
daft 

eine Zeitiiberschreitung aufgrund eines Zeitraums erfolgt, 
indem Daten ubertragen wurden. 

35. Verfahren nach Anspruch 14 bis 32 dadurch gekennzeichet, 
daft 

eine Zeitiiberschreitung aufgrund der ubertragenen Datenmenge 
erfolgt . 

36. Verfahren nach Anspruch 14 bis 32 dadurch gekennzeichet, 
daft 

eine Zeitiiberschreitung nicht moglich ist. 
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37. Verfahren nach Anspruch 14 bis 36 dadurch gekennzeichet, 
dafi 

das verwendete Zeitiiberschreitungsverf ahren fur jedes 
Bussegment gemaJi den Anspriichen 33 bis 36 selektiv gewahlt 
wird. 
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